@media screen and (min-width: 751px) {
	#main{
		margin-top: 180px
	}
	.footer-test.to-top.bnr_summer.bnr_fix {
		bottom: 580px;
        width: fit-content;
        height: auto;
        right: 10px;
	}
	
    /*Navigation*/
    .main-nav {
        position: relative;
        top: 0;
        left: 0;
        width: 100%;
        z-index: 101;
        display: block !important;
        background: #2c86cc;
        height: 80px;
    }

    .slick-dots-cus a:hover {
        opacity: 0.7
    }

    .box-header {
        height: 180px;
		position: fixed;
        z-index: 9999;
		background: #fff
    }

    .logo img {
        display: block;
        margin-left: -2px;
    }

    .box-header .inner02 {
        height: 100px;
    }

    .box-sp {
        display: none !important
    }

    #header.fixed-nav .main-nav {
        position: fixed
    }

    #header.fixed-nav {
        padding-bottom: 78px
    }

    .main-nav ul.nav {
        margin: 0 -5px
    }

    .main-nav ul.nav > li > a {
        display: flex;
        height: 80px;
        align-items: center;
        color: #fff;
        text-decoration: none;
        position: relative;
        font-size: 16px;
        font-weight: bold;
    }

    .main-nav ul.nav > li.parent {
        position: relative;
        background-size: 20px
    }

    .h-information {
        margin-bottom: 0
    }

    .main-nav ul.nav > li.parent > a {
        cursor: default
    }

    .main-nav .sub {
        position: absolute;
        z-index: 1;
        transition: all .3s;
        opacity: 0;
        transform: translate(-3px, 3px);
        visibility: hidden;
        border-top: solid 1px rgba(255, 255, 255, 0.3);
        width: 300px;
        top: calc(100% - 1px);
        left: 0
    }

    .main-nav .sub ul li a {
        font-size: 16px;
        font-weight: 400;
        display: flex;
        width: 100%;
        height: 60px;
        align-items: center;
        text-decoration: none;
        letter-spacing: .001em;
        padding: 5px 35px;
        margin: 0 auto;
        border-bottom: solid 1px rgba(255, 255, 255, 0.3);
        background: url("../images/icon-menu-right.png") no-repeat left 20px center /6px #2c86cc;
        color: #fff;
        line-height: 1.6
    }

    .main-nav .sub ul li:last-child {
        margin-bottom: 0
    }

    .sec04-btn a {
        width: 390px;
        height: 70px;
        border-radius: 20px;
        letter-spacing: 0.06rem;
    }

    .sec04-btn a::after {
        border-radius: 20px;
        bottom: -6px;
    }

    /*end Navigation*/
    .hamburger {
        display: none;
        position: fixed;
        z-index: 101
    }

    #box-contact-mobi {
        display: none !important
    }

    .sec03-item-orange {
        margin-bottom: 50px !important;
    }

    .sec03-item-blue {
        margin-bottom: 17px !important;
    }

    .sec03-item-pink .title {
        line-height: 1.4;
        margin-bottom: 30px;
    }

    .sec03-item-orange .title {
        line-height: 1.4;
        white-space: nowrap;
        margin-bottom: 25px;
    }

    .sec05-inner {
        width: 1500px;
    }

    footer {
        margin-bottom: 140px;
    }

    .contact-pc-group-btn .btn-line a {
        letter-spacing: -0.1rem;
        white-space: nowrap;
        font-size: 18px;
    }
	
    .box-header.active {
        height: 160px;
    }

    .box-header.active .main-nav,
    .box-header.active .main-nav ul.nav > li > a {
        height: 60px;
    }

    .header-contact a:hover {
        opacity: 0.7;
    }

    .box-header.active .main-nav ul.nav li a::after {
        bottom: 12px;
    }

    .sec06-inner {
        width: 1200px !important;
    }

    /*==========================================================
                            HOVER
    ==========================================================*/
    .main-nav ul.nav li a::after {
        content: "";
        position: absolute;
        width: 0;
        height: 1px;
        background-color: #FFF;
        bottom: 22px;
        left: 0;
        transition: all 0.3s;
    }

    .main-nav ul.nav > li:hover > a::after {
        width: 100%;
    }

    .sec02-video-box:hover {
        cursor: pointer;
    }

    .sec02-video-box:hover::after,
    .sec07-banner:hover {
        opacity: 0.7;
    }
    .list-news .tt:hover,
    .sec04-list dl .tt:hover {
        text-decoration: underline;
    }

    .sec04-list dl dt:hover img {
        transform: scale(1.1);
    }

    .sec05-list li a:hover {
        transform: translateY(-5px);
    }

    .sec03-banner img:hover {
        opacity: 0.7;
    }


    #ft-link .inner ul li a:hover {
        color: #2c86cc;
        text-decoration: underline;
    }

    .ft-bnn-list img{ height: 80px !important; width: auto !important;}

    .main-nav ul.nav > li:hover a {
        color: #fff
    }

    .main-nav .parent:hover .sub {
        opacity: 1;
        transform: translate(0, 0);
        visibility: visible
    }

    .main-nav .sub li:hover {
        background-color: #4e9fd4
    }

    .main-nav .sub a:hover {
        background-color: #4e9fd4
    }

    .to-top img:hover {
        opacity: .8
    }

    .btn-primary a:not([target="_blank"]):hover {
        background-image: linear-gradient(to left, #2c86cc, #4e9fd4) !important;
        color: #FFF !important;
    }

    .btn-primary.sec05-btn a:hover {
        background: #fad23c !important;
    }

    .contact-pc-group-btn .btn-line a:hover::before {
        background: url('../images/ic-line-hover.png') no-repeat center /cover
    }

    #wrap-slider #slider li a:hover img {
        opacity: 0.8
    }

    .box01-item {
        width: 1200px;
        margin: 0 auto;
        position: absolute;
        bottom: 40px;
        left: 0;
        right: 0;
      }
.sec02-box .sec02-title::after {
    content: "";
    position: absolute;
    width: 150px;
    height: 97px;
    bottom: -40px;
    right: -39px;
    z-index: 1;
    background: url('../images/sec02-video-ic.png') no-repeat center /cover;
}
	
    /* =============== E N D - H O V E R =========== */
}

@media screen and (min-width: 1521px) and (max-width: 1850px) {
    .sec08-image {
        margin-left: 0;
    }

    .sec08-image img {
        width: 650px;
        height: auto;
    }
}

@media screen and (min-width: 751px) and (max-width: 1520px) {
    #index img {
        height: auto ;
    }
    .ft-bnn-list img {
        height: 80px !important;
        width: auto !important;
      }

    .inner02 {
        width: 1200px
    }

    .box-header .inner02 {
        width: 100%;
        max-width: 1300px;
        padding-left: 5px;
    }

    .heacer-construction {
        margin-right: 10px;
    }

    .header-phone {
        margin-right: 30px;
    }

    #box-contact-pc .inner02 {
        width: calc(100% - 20px);
    }

    #box-contact-pc {
        height: 130px;
    }

    #box-contact-pc dl {
        height: 90px;
    }
	.ft-link-company {
		margin-right: 40px;
	}
	.sec09-h3 .lg {
		font-size: 42px;
	}
	/* PC小（751-1520px）: 吹き出しを画面内に収まる位置へ */
	.sec09-h3 .sm::before {
		right: -300px;
		top: 10px;
	}
	.sec09-h3 .lg::before {
		right: -200px;
		top: -80px;
	}
    #box-contact-pc dl dt {
        width: 170px;
        font-size: 16px;
    }
	.ytb-btn-cus {
		width: 200px;
		top: -50px;
		right: 80px;
	}
	.contact-pc-phone {
		margin-right: 10px;
		padding-left: 45px;
	}
	.sec09-image {
		right: 0;
	}
    #box-contact-pc dl dd {
        width: auto;
        padding-right: 20px;
        padding-left: 0;
    }

    .contact-pc-group-btn .btn-primary a {
        width: 280px;
        font-size: 17px;
        height: 60px;
        padding-top: 5px;
    }

    .contact-pc-group-btn .btn-contact a {
        font-size: 18px;
    }

    .contact-pc-phone .numm {
        font-size: 24px;
    }

    .contact-pc-phone .time {
        font-size: 14px;
    }

    .contact-pc-phone .numm::before {
        width: 30px;
        height: 30px;
        top: calc(50% - 15px);
        left: -35px;
    }

    .to-top {
        bottom: 35px;
    }

    .to-top.lg {
        bottom: 420px;
    }

    .to-top.youtube {
        bottom: 100px;
    }

    .footer-test.to-top.youtube {
        bottom: 100px;
        width: 227px;
    }


    .to-top.floating {
        bottom: 130px;
    }

    .to-top.youtube.bnr_fix {
        bottom: 280px;
    }


    .footer-test.to-top.youtube.bnr_fix{
        bottom: 265px;
    }
    .footer-test.box_pc.to-top.lg{
        bottom: 415px;
        width: 210px;
    }

    #sec01 {
        background-position: -190px;
    }

    .big50 {
        font-size: 45px;
    }

    .big40 {
        font-size: 36px;
    }

    .sec05-inner {
        width: calc(100% - 20px);
    }

    .sec05-list li {
        width: 32%;
    }

    .sec05-list li .tt {
        font-size: 20px;
    }

    .sec05-list li a {
        width: 100%;
        height: 100%;
    }

    .sec05-list li:not(3n) {
        margin-right: 3%;
    }

    .se07-inner {
        width: calc(100% - 20px);
    }

    .sec07-item {
        width: 49%;
        padding-bottom: 20px;
    }

    .sec07-tt {
        background-size: 100% !important;
        transform: scale(0.9)
    }

    .sec07-tt .lg {
        font-size: 42px;
    }

    #index .sec07-list-bnn dl {
        transform: scale(0.81) !important;
    }

    #index .sec07-list-bnn dl:not(:last-child) {
        margin-bottom: -10px;
    }

    .sec08-image {
        margin-left: 30px;
        width: 48%;
    }

    .sec08-image::before {
        transform: scale(0.8);
    }

    .sec08-image {
        margin-right: 20px;
    }

    .sec08-box {
        width: 48%;
    }

    .sec08-title {
        transform: scale(0.8);
        z-index: -1;
        margin-bottom: 5px;
    }

    .sec08-des {
        margin-bottom: 20px;
    }

    .sec08-btn .btn-primary a {
        width: 180px;
        height: 55px;
        font-size: 16px;
    }

    #sec08 {
        padding-bottom: 80px;
    }

    footer {
        margin-bottom: 130px;
    }

    .sec02-video::after {
        right: -30px;
    }

    .main-nav ul.nav {
        margin: 0;
    }

}
@media screen and (max-height: 920px) and (max-width: 1400px) {
	.mv_txt {
  /*top: 30%;*/
	bottom: 150px;
}
.mv_txt h2 {
  font-size: 40px;
	margin-bottom: 5px;
}
	.box01-item {
    bottom: 10px;
  }
}
@media screen and (max-height: 750px) {
	body #box-contact-pc dl dd {
		width: auto;
        padding-right: 20px;
	}
	body .contact-pc-phone .numm {
		font-size: 20px;
	}
	body .contact-pc-phone {
		padding-left: 45px;
		margin-right: 15px;
	}
	body .ytb-btn-cus {
		right: 105px;
        top: -40px;
        width: 180px;
	}
	body .footer-test.to-top.youtube.bnr_fix {
		bottom: 255px;
		width: 140px;
	}
	body .footer-test.to-top.google.bnr_fix {
		width: 140px;
		bottom: 340px;
	}
	body .footer-test.to-top.bnr_summer.bnr_fix {
		bottom: 425px;
        width: 140px;
	}
}
@media screen and (min-width: 751px) and (max-width: 1260px) {
    .slick-slide img {
        width: 1260px;
    }

    .sec05-list li a {
        padding: 21px 20px 50px;
    }

}
@media screen and (min-width: 1366px) and (max-width: 1366px){
    .footer-test.box_pc.to-top.lg {
        bottom: 385px;
        width: 200px;
    }

    .footer-test.to-top.youtube{
        width: 200px;
    }

    .footer-test.to-top.youtube.bnr_fix{
        bottom: 255px;
    }
}

@media screen and (min-width: 751px) and (max-width: 1366px) {
    .footer-test.to-top.youtube {
        width: 195px !important;
    }
    .footer-test.to-top.youtube.bnr_fix {
        bottom: 30% !important;
    }
    .footer-test.to-top.google.bnr_fix {
        bottom: 45% !important;
        width: 195px !important;
    }
    .footer-test.to-top.bnr_summer.bnr_fix{
        width: 195px !important;
        bottom: 60%;
    }

}
/* screen-min:750px */
@media screen and (max-width: 750px) {
	.bnr_tosoday.show {
	  transform: scale(1);
	  opacity: 1;
	  visibility: visible
	}
	
	.bnr_tosoday {
		position: fixed;
		bottom: 200px;
		right: 0;
		z-index: 99;
		cursor: pointer;
		transition: all .2s;
		opacity: 0;
		visibility: hidden
	}
	.bnr_tosoday img {
		width: 116px;
	}
	
	#header .box-header.active{
		background: none
	}
	.box-list {
		display: block;
	}
	.box-item {
		margin-right: 0;
		border-right: 0;
		padding-right: 0;
		margin-bottom: 40px;
		padding-bottom: 40px;
		border-bottom: 2px solid #fad23c;
	}
	.box-list .box-item:last-child {
		margin-bottom: 0;
		padding-bottom: 0;
		border-bottom: 0;
	}
    .box_sp {
        display: block;
    }

    .box_pc {
        display: none;
    }

    #index img {
        height: auto !important;
    }

    p {
        font-size: 14px;
    }

    img {
        max-width: 100%
    }

    #wrapper,
    #header,
    #main,
    #footer,
    .inner,
    .under .under-inner,
    .inner02 {
        width: 100% !important;
        min-width: unset !important
    }

    .inner,
    .inner02 {
        box-sizing: border-box;
        padding: 0 10px
    }

    .box-pc {
        display: none !important
    }

    .h3-underStyle {
        font-size: 24px;
        margin-bottom: 0px;
        background-size: 120px auto;
        padding: 45px 0 30px;
    }

    #header .box-header {
        position: fixed;
        z-index: 10;
        background-color: #fff;
        height: 60px;
    }

    #header h1 {
        display: none;
    }

    /*----------------------------------------------*/
    .customize-support .main-nav {
        top: 105px;
    }


    .main-nav {
        display: block;
        position: fixed;
        top: 60px;
        left: 0;
        width: 100%;
        height: calc(100vh - 60px);
        overflow: auto;
        padding-bottom: 80px;
        background: #2c86cc;
        z-index: 100;
        display: none
    }

    .main-nav .nav {
        flex-direction: column;
        margin-bottom: 30px;
    }

    .main-nav .nav li {
        width: 100%
    }

    .main-nav .nav ul {
        width: 100%
    }

    .main-nav a {
        display: block;
        padding: 13px 15px 14px;
        background: #2c86cc;
        color: #fff;
        font-size: 16px;
        font-weight: 500;
        text-decoration: none;
        border-bottom: solid 1px #ccc
    }

    .main-nav a[href] {
        background-position: left 17px center;
        background-repeat: no-repeat /3px
    }

    .main-nav .parent .sub ul li {
        background: url("../images/icon-menu-right.png") left 37px center no-repeat /6px #fff;
        padding-left: 0;
    }

    .main-nav .parent .sub ul li:not(:last-child) {
        border-bottom: 1px solid #2c86cc
    }

    .main-nav a:not([href]) {
        background: #2c86cc;
        position: relative;
        padding-left: 15px
    }

    .main-nav a:not([href]):before {
        content: "";
        border-top: solid 8px #fff;
        border-left: solid 8px transparent;
        border-right: solid 8px transparent;
        position: absolute;
        right: 20px;
        top: 25px
    }

    .main-nav a.open:not([href]):before {
        transform: rotateZ(180deg);
        top: 25px
    }

    .main-nav .sub {
        background: #2c86cc;
        border-bottom: solid 1px #fff;
        display: none
    }

    .main-nav .sub ul:not(:last-child) {
        margin-bottom: 15px
    }

    .main-nav .sub ul li.ttl {
        font-size: 18px;
        font-weight: 600;
        padding: 0 15px;
        color: #fff
    }

    .main-nav .sub a {
        background-color: #fff;
        font-weight: 200;
        color: #2c86cc;
        background-position: left 17px top 13px;
        border-bottom: none;
        padding: 4px 0 4px;
        height: 50px;
        display: flex;
        align-items: center;
        line-height: 1.3;
        padding-left: 3%;
    }

    .box-logo {
        margin-bottom: 0;
    }

    .h-information {
        padding: 0 7px 2px;
        height: 60px;
        z-index: 97;
    }

    .h-information .header-contact {
        display: none
    }

    .h-information .logo {
        padding-top: 0;
        margin: auto auto auto 0;
        width: 194px;
        padding-bottom: 0;
        margin-right: 10px;
    }

    .h-information .logo > a {
        display: inline-block
    }

    .h-information .info-buttons {
        position: fixed;
        bottom: -100%;
        left: 0;
        width: 100%;
        background: #fff;
        padding: 5px;
        justify-content: center;
        transition: all .5s
    }

    .h-information .info-buttons.show {
        bottom: 0
    }

    .h-information .info-buttons li {
        max-width: calc(50% - 10px);
        margin-right: 10px
    }

    .h-information .info-buttons li:last-child {
        margin-right: 0
    }

    .hamburger {
        position: absolute;
        right: 0;
        bottom: 0;
        font: inherit;
        display: block;
        overflow: visible;
        margin: 0;
        cursor: pointer;
        transition-timing-function: linear;
        transition-duration: .15s;
        transition-property: opacity, filter;
        text-transform: none;
        color: inherit;
        border: 0;
        background-color: #2c86cc;
        border: 1px solid white;
        height: 60px;
        width: 60px;
        padding: 19px 10px 4px 13px;
    }

    .hamburger-box-text {
        font-size: 14px;
        font-weight: 700;
        cursor: pointer;
        color: #fff
    }

    .idx-fixed {
        position: fixed !important;
        z-index: 9999;
        background-color: #fff
    }

    #header {
        position: relative;
        z-index: 9999;
        width: 100%;
        background: #fff;
        border-bottom: solid 1px rgba(0, 0, 0, 0.1)
    }

    #header .inner {
        padding: 0
    }

    .h-infomation-box {
        width: 100%;
    }

    .to-top {
        width: 40px;
        height: 40px;
        right: 10px;
        bottom: 70px !important;
    }

    .footer-test.to-top{
        bottom: 135px !important;
    }

    .to-top.floating {
        right: 110px;
    }

    /* .to-top a img {
        bottom: 0;
        position: absolute
    } */

    .to-top:before {
        width: 10px;
        height: 10px;
        left: 12px;
        top: 12px
    }

    .to-top:after {
        width: 10px;
        height: 10px;
        left: 12px;
        top: 20px
    }

    .box-header .header-phone {
        display: none;
    }

    .heacer-construction {
        width: 100px;
        margin-top: 2px;
        margin-right: 0px;
        padding-top: 10px;
    }

    .box-header .inner02 {
        padding: 0;
    }

    .box-logo .heacer-construction .first_img {
        width: 84px;
        position: initial;
    }

    .box-logo .heacer-construction .second_img {
        width: 52px;
        position: initial;
    }

    /*=======================  C U S T O M ====================*/
    .btn-primary a {
        font-size: 15px;
    }

    /*============================= SLIDER =============================*/
    #wrap-slider {
        padding-top: 69px;
    }

    #wrap-slider #slider {
        height: 100%;
    }

    #wrap-slider #slider li.slide-item {
        width: 100vw;
    }

    #wrap-slider .slick-dots {
        height: 100%;
    }

    #wrap-slider .slick-dots li {
        width: 29vw;
        margin: 0 2vw;
    }

    .list-news-tt {
        width: 150px;
        font-size: 16px;
    }

    .list-news {
        width: calc(100% - 150px);
        padding: 10px 2% 10px 20px;
    }

    .list-news li {
        display: flex !important;
        padding-top: 0;
    }

    .box-list-news {
        margin-top: 20px;
    }

    .box-list-news .inner {
        height: 50px;
    }

    .list-news .tt {
        font-size: 14px;
        width: 100%;
    }

    .list-news .date {
        margin-right: 20px;
    }

    /*============================= SEC1 =============================*/
    #sec01 {
        background-position: left -570px center;
        padding: 40px 0 52vw;
        height: 100%;
        background-size: cover;
        background: url('../images/sec01-bkg-sp.jpg') no-repeat center bottom /100vw;
    }

    .sec01-title {
        margin-left: auto;
        margin-right: auto;
        max-width: 600px;
        width: 100%;
        height: auto;
    }

    .sec01-logo {
        margin-right: 0;
        margin-bottom: 10px;
    }
    .sec01-logo img{ width: 100%;}

    .sec01-sub {
        padding-left: 0;
        max-width: 300px;
    }

    /*============================= SEC2 =============================*/
    #sec02 {
        padding: 40px 0;
    }

    .sec02-box {
        flex-direction: column;
        padding-left: 0;
    }

    .sec02-box .sec02-title,
    .sec02-box .sec02-video {
        width: 100%;
        margin-left: auto;
        margin-right: auto;
    }

    .sec02-title {
        display: flex;
        flex-direction: column;
        justify-content: center;
        align-items: center;
    }

    .sec02-video {
        margin-bottom: 30px;
    }

    .sec02-desc {
		position: relative;
        color: #FFF;
    }

    .sec02-video{
        position: relative;
        padding-top: 56.25%;
        height: 0; 
        width: 100%;
        box-sizing: border-box;
    }
    .sec02-video lite-youtube {
        position: absolute;
        top: 0;
        left: 0;
        width: 100% !important;
        height: 100% !important;
        box-sizing: border-box;
    }
/*.sec02-box .sec02-desc::after {
    content: "";
    position: absolute;
            width: 15vw;
        height: 9vw;
        right: -5px;
        bottom: 0;
    z-index: 1;
    background: url('../images/sec02-video-ic.png') no-repeat center /cover;
}*/
	.sec02-video::after {
    content: "";
    position: absolute;
    width: 15vw;
        height: 9vw;
        right: -5px;
        bottom: -4vw;
    z-index: 1;
    background: url('../images/sec02-video-ic.png') no-repeat center /cover;
}
    .sec02-h3,
    .big40 {
        font-size: 30px;
    }

    .big50 {
        font-size: 40px;
    }

    .sec02-video::after {
        width: 15vw;
        height: 9vw;
        right: -5px;
        bottom: -4vw;
    }

    .sec02-video-box img {
        margin: 0 auto;
        display: block;
    }

    .sec02-video-box::after {
        width: 60px;
        height: 60px;
        background-size: cover;
        left: calc(50% - 30px);
        top: calc(50% - 30px);
    }

    .sec02-video-tt {
        width: 150px;
        left: calc(50% - 75px);
    }

    /*============================= SEC3 =============================*/
    #sec03 {
        padding: 40px 0 47px;
    }

    .sec03-h3 {
        max-width: 540px;
        margin: 0 auto 20px auto;
        padding-right: 0;
    }

    .sec03-item-img {
        width: 200px;
        display: flex;
        justify-content: center;
        align-items: center;
    }

    .sec03-item:nth-of-type(odd) .sec03-item-img {
        margin-right: 10px;
    }

    .sec03-item:nth-of-type(even) .sec03-item-img {
        margin-left: 10px;
    }

    .sec03-item .title {
        font-size: 2.8vw;
    }

    .sec03-list {
        padding: 40px 2% 70px;
    }

    .btn-primary a {
        height: 50px;
    }

    .sec03-item-content .btn-primary::after {
        bottom: -40px;
    }

    .sec03-item-content .btn-primary a {
        width: 220px;
        padding-top: 0;
    }

    .sec03-list .sec03-item:not(:last-child) {
        margin-bottom: 50px;
    }

    .sec03-item-content .slogan {
        width: 160px;
        height: 30px;
        font-size: 14px;
        margin-bottom: 12px;
    }

    .sec03-item-content::before {
        font-size: 80px;
    }

    .sec03-item-orange .title {
        font-size: 2.4vw;
    }

    .sec03-item-green .sec03-item-content {
        padding-top: 0;
    }

    .btn-primary.big a {
        width: 340px;
        height: 70px;
        font-size: 22px;
        padding-top: 5px;
    }

    .btn-primary.big a::before {
        right: 20px;
        width: 12px;
        height: 19px;
        top: calc(50% - 9px);
    }

    .sec03-list {
        margin-bottom: 40px;
    }

    /*============================= SEC4 =============================*/
    .box-banner-top {
        padding: 0 0 40px;
    }

    .banner-top-content {
        margin-bottom: 20px;
    }

    .box-banner-top .inner {
        flex-direction: column;
    }

    .box-banner-top .tt01,
    .box-banner-top .tt03 {
        font-size: 4vw;
    }

    .box-banner-top .tt02 {
        width: 67vw;
    }

    .box-banner-top .slogan {
        width: 100%;
        height: 6vw;
        font-size: 3.1vw;
        padding-left: 5vw;
    }

    .banner-top-map .map {
        display: flex;
        justify-content: center;
        align-items: center;
    }

    .box-banner-top .inner {
        padding: 40px 10px 31px;
    }

    .box-banner-top .slogan::after {
        width: 20vw;
        height: 19.5vw;
        bottom: -11vw;
        right: 2vw;
    }

    .banner-top-map .btn-primary a {
        width: 320px;
        height: 60px;
    }

    #sec04 {
        background: url('../images/sec04-bkg.jpg') no-repeat right top /750px;
        padding: 60px 0 50px;
        position: relative;
    }

    .sec04-des {
        margin-bottom: 25px;
    }

    .sec04-list dl {
        width: 31vw;
    }

    .sec04-list .cate {
        width: 120px;
        height: 30px;
        font-size: 14px;
    }

    .sec04-list dl dd {
        padding: 10px;
    }

    .sec04-list dl .tt {
        font-size: 16px;
    }

    .sec04-list dl dd {
        font-size: 14px;
    }

    .sec04-h3 {
        font-size: 30px;
    }

    .group-btn {
        flex-direction: column;
    }

    .group-btn .btn-primary:not(:last-child) {
        margin-right: 0;
        margin-bottom: 20px;
    }

    .sec04-btn a {
        width: 300px;
        height: 60px;
        font-size: 18px;
    }

    .sec04-slogan {
        font-size: 3.5vw;
    }

    .sec04-slogan > span::before,
    .sec04-slogan > span::after {
        width: 5.5vw;
        height: 7vw;
    }

    .sec04-slogan > span::after {
        right: -5vw;
    }

    .sec04-slogan > span::before {
        left: -6vw;
    }

    /*============================= SEC5 =============================*/
    #sec05 {
        padding: 40px 0;
    }

    .sec05-h3 span {
        font-size: 30px;
    }

    .sec05-h3 {
        font-size: 24px;
    }

    .sec05-list {
        margin-bottom: 10px;
    }

    .sec05-list li {
        width: 49%;
        margin-bottom: 30px !important;
    }

    .sec05-list li a {
        width: 100%;
        height: 100%;
        padding: 20px 3% 50px;
    }

    .sec05-list li .tt {
        font-size: 17px;
    }

    .sec05-btn a {
        width: 300px;
    }

    /*============================= SEC6 =============================*/
    #sec06 {
        padding: 40px 10px 100px;
    }

    .sec06-inner {
        flex-wrap: wrap;
        padding: 30px 3% 40px;
        justify-content: center;
    }

    .sec06-phone {
        width: 35%;
        margin-bottom: 40px !important;
        order: 2;
        margin-left: 0;
        flex-shrink: 1;
    }

    .sec06-phone img {
        display: block;
        margin-top: 30px;
        max-width: 100%;
    }

    .sec06-box {
        order: 3;
        width: 100%;
    }

    .sec06-img {
        width: 50%;
        display: flex;
        justify-content: center;
        align-items: center;
        margin-bottom: 40px;
    }

    .sec06-img img {
        width: 100%;
        max-width: 250px;
    }

    .sec06-slogan span {
        font-size: 2.5vw;
        margin-left: 0;
        padding: 5px 4vw;
    }

    .sec06-h3 {
        font-size: 5vw !important;
    }

    .sec06-des {
        font-size: 16px;
    }

    .sec06-btn a {
        font-size: 20px;
    }

    .sec06-btn a::before {
        width: 12px;
        height: 19px;
        top: calc(50% - 9px);
    }

    /*============================= SEC7 =============================*/
    #sec07 {
        padding-bottom: 40px;
    }

    .sec07-h3 {
        transform: translateY(-60px) !important;
        font-size: 3.2vw;
        padding: 15px 2vw;
    }

    .sec07-list {
        flex-direction: column;
        margin-top: -20px;
        margin-bottom: 30px;
    }

    .sec07-item:not(:last-child) {
        margin-bottom: 30px;
    }

    .sec07-tt {
        width: 90vw;
        height: 18vw;
        background-size: 90vw !important;
    }

    .sec07-item {
        width: 100%;
    }

    .sec07-tt .sm {
        font-size: 3.4vw;
    }

    .sec07-tt .lg {
        font-size: 6.4vw;
    }

    .sec07-list-bnn dl dt {
        padding: 5px 1.5vw 5px 1vw;
    }

    .sec07-list-bnn dl dd {
        padding: 10px 2vw;
    }

    .sec07-list-bnn dl .durability .key {
        width: 12vw;
        height: 3.5vw;
    }

    .sec07-list-bnn dl .durability {
        margin-right: 2vw;
    }

    .sec07-des {
        font-size: 2.8vw;
    }

    .sec07-list-bnn dl .title .lg {
        font-size: 3.6vw;
    }

    .sec07-list-bnn dl .title .sm {
        font-size: 2vw;
    }

    .sec07-list-bnn dl dt {
        font-size: 2.1vw;
    }

    .sec07-list-bnn dl .durability .key {
        font-size: 1.9vw;
    }

    .sec07-list-bnn dl .durability .val {
        font-size: 4vw;
    }

    .sec07-list-bnn dl .money .numm {
        font-size: 6vw;
    }

    .sec07-list-bnn dl .money .numm .sm {
        font-size: 4vw;
    }

    .sec07-list-bnn dl .money .val .lg {
        font-size: 3vw;
    }

    .sec07-list-bnn dl .money .val {
        font-size: 1.7vw;
    }

    .sec07-list-bnn dl .box-money .vat {
        font-size: 2.5vw;
    }

    .sec07-list-bnn dl {
        width: 93vw;
        height: 14vw;
    }

    /*============================= SEC8 =============================*/
    #sec08 {
        padding: 40px 0;
    }

    .sec08-inner {
        flex-direction: column;
    }

    .sec08-image {
        margin: 0 auto 100px auto;
        width: 90vw;
    }

    .sec08-image::before {
        width: 51vw;
        height: 15vw;
        left: -8vw;
        bottom: -10vw;
    }

    .sec08-title {
        max-width: 300px;
        margin: 0 auto 30px auto;
        padding-right: 0;
    }

    .sec08-title::after {
        left: calc(50% - 30vw);
        width: 62vw;
        height: 42vw;
        bottom: -17vw;
        background-size: cover;
    }

    .sec08-box {
        width: 100%;
        padding-bottom: 0;
    }

    .sec08-btn {
        flex-direction: row;
        margin-left: 0;
    }

    .sec08-btn .btn-primary {
        margin-bottom: 0 !important;
    }

    .sec08-btn .btn-primary:not(:last-child) {
        margin-right: 20px;
    }

    .sec08-btn .btn-primary a {
        width: 190px;
    }

    /*============================= SEC9 =============================*/
    #sec09 {
        padding: 70px 0 50px;
    }
	.sec09-banner02 {
        margin-top: 0
    }
    .sec09-h3 .sm {
        font-size: 4vw;
    }

    .sec09-h3 .lg {
        font-size: 5vw;
        white-space: nowrap;
    }

    .sec09-h3 .lg:after {
        width: 90vw;
        height: 3.5vw;
        z-index: -1;
    }

    /* SP では吹き出しは小さく、タイトル下部に配置（重なり防止） */
    .sec09-h3 .sm::before {
        display: none;
    }

    .sec09-h3 .lg::before {
        display: none;
    }

    .sec09-banner {
        padding: 30px 10px 35px;
    }

    .sec09-banner-tt {
        font-size: 4vw;
        line-height: 1.4;
        transform: translateX(-10px);
    }

    .sec09-group {
        flex-direction: column;
    }

    .sec09-group-btn {
        flex-direction: row;
    }

    .sec09-btn a {
        width: 250px;
    }

    .sec09-phone .phone {
        font-size: 44px;
        white-space: nowrap;
    }

    .sec09-group-btn .sec09-btn:not(:last-child) {
        margin-bottom: 0;
        margin-right: 10px;
    }

    .sec09-phone {
        margin-bottom: 20px;
        padding-left: 55px;
    }

    .sec09-phone .phone:before {
        width: 30px;
        height: 30px;
        top: 8px;
        left: -28px;
    }

    .sec09-banner:before {
        width: 20vw;
        height: 16vw;
    }

    .sec09-banner::after {
        width: 20vw;
        height: 23vw;
    }

    .sec09-phone .time {
        margin-left: -20px;
        white-space: nowrap;
    }

    .sec09-image {
        display: none;
    }

    .sec09-inner > div {
        margin-bottom: 20px;
    }

    .b03_info_btn a:not([target="_blank"]):hover,
    .f_call_btn a:not([target="_blank"]):hover {
        background: #fff;
        color: #e8be2a;
    }

    .b03_info_btn a:not([target="_blank"]):hover:before,
    .f_call_btn a:not([target="_blank"]):hover:before {
        background-image: url("https://www.paintplaza.co.jp/wp-content/themes/PaintPlaza/images/idx_icon_mail_hv.svg");
    }

    .f_call_btn li:nth-child(2) a:hover,
    .b03_info_btn li:nth-child(2) a:hover {
        background: #fff;
        color: #03c755;
    }

    .b03_info {
        display: block;
        margin: -30px 0 0;
        flex-wrap: wrap;
        border-radius: 3vw;
        padding-bottom: 11vw;
    }

    .pc {
        display: none;
    }

    .b03_info_btn {
        padding: 0 3vw 0;
        width: 100%;
        margin: 0 auto;
    }

    .b03_info_tel {
        font-size: 4vw;
        width: 100%;
        padding: 0 2vw 0 3vw;
        margin: 0;
    }

    .b03_info_note .idx_point {
        margin: 0 -1vw;
    }

    .b03_info_tel_num:before {
        width: 7vw;
        height: 7vw;
        margin-right: 1.5vw;
    }

    .b03_info_txt {
        letter-spacing: 0;
        margin-bottom: 1vw;
        padding: 0 2px;
        font-size: 6vw;
    }

    .b03_info_time {
        letter-spacing: -0.05em;
        white-space: nowrap
    }

    .b03_info_ttl {
        width: 100%;
        height: auto;
        padding: 5vw 3vw 0vw;
        text-align: center;
        display: block;
        font-size: 4vw;
        border-bottom-left-radius: 0;
        border-top-right-radius: 3vw;
        border-top-left-radius: 3vw;
        margin-bottom: 8vw;
    }

    /* 黄色い矢印（b03_icon01.svg）— SPでは非表示 */
    .b03_info:before {
        display: none;
    }

    .b03_info_ttl:after {
        border-width: 5vw 47vw 0 47vw;
        border-color: #1e6ca8 transparent transparent transparent;
        right: auto;
        bottom: -4.9vw;
        top: auto;
        left: 0;
    }

    .b03_info_btn a:before {
        margin: 0 1.5vw 0 0;
        width: 5.5vw;
        height: 4.5vw;
        top: 0.3vw;
    }

    .b03_info_btn a {
        width: 100%;
        font-size: 5vw;
        padding: 1.5vw 0.5vw 1.8vw !important;
        height: 17vw;
    }

    .b03_info_btn li:nth-child(1) a{
        height: 15vw;
    }
    .b03_info_btn li:nth-child(2) a{
        height: 15vw;
    }
    .b03_info_btn li:nth-child(3) a{
        font-size: 4vw;
        height: 15vw;
    }

    .b03_info_note {
        font-size: 7vw;
        margin-bottom: 15px;
    }

    .b03_24h .b03_info_note {
        margin-top: 25px;
        margin-right: 0;
        font-size: 7vw;
    }

    .b03_info_tel_num {
        font-size: 9vw;
    }

    .b03_info_btn li:not(:last-child) {
        margin-bottom: 2vw;
    }

    .b03_info_btn li:nth-child(2) a:before {
        width: 9vw;
        height: 9vw;
        margin: 0 1vw 0 0;
    }
    .b03_info_btn li:nth-child(3) a:before {
        width: 6vw;
        height: 6vw;
        margin: 0 3vw 0 0;
    }


    /*============================= FOOTER =============================*/
    /* Address */
    #box-copyright {
        margin-bottom: 50px;
        height: 30px
    }

    #box-copyright p {
        font-size: 12px
    }

    /* FT-TOP */
    /* FT-LINK */
    #ft-link {
        height: 100%;
        padding: 30px 0 80px;
    }

    .ft-link-url {
        display: none;
    }

    .ft-logo {
        width: 300px;
        margin-bottom: 20px;
    }

    #ft-bnn {
        padding: 30px 0 0;
    }

    .ft-bnn-list p:not(:last-child) {
        margin-right: 10px;
    }

    .ft-bnn-list .bnn-txt {
        width: 33vw;
        height: 10.5vw;
        font-size: 2.2vw;
        flex-shrink: 0;
    }

    .idx-copy-right {
        height: 80px;
        margin-bottom: 60px;
        display: flex;
        justify-content: center;
        align-items: center;
        font-weight: 14px;
        color: #2c86cc;
        text-align: center;
    }

    .ft-link-company {
        margin: 0 auto;
    }

    .idx-copy-right p {
        line-height: 1.6;
    }

    .ft-add {
        padding-left: 0;
        font-size: 14px;
        margin-bottom: 20px;
        text-align: center;
    }

    .ft-copy {
        text-align: center;
    }

    /*============================= BOX-CONTACT-MOBi=============================*/
    #box-contact-mobi {
        justify-items: center;
        align-items: center;
        width: 100%;
        height: 60px;
        position: fixed;
        bottom: 0;
        left: 0;
        z-index: 999
    }

    #box-contact-mobi p {
        height: 100%;
        margin: 0
    }

    #box-contact-mobi .header-contact a {
        width: 100%;
        height: 100%;
        padding-top: 3px;
        padding-right: 2vw;
    }

    #box-contact-mobi .header-phone {
        width: 38vw;
        background-color: #FFf;
        padding-right: 20px;
        padding-bottom: 5px;
    }

    #box-contact-mobi .header-contact {
        width: 34vw;
        background-color: #fad23c;
    }

    #box-contact-mobi .header-line {
        width: 28vw;
        background-color: #06c755;
        display: flex;
        justify-content: center;
        align-items: center;
        text-align: center;
        line-height: 1.4;
    }

    #box-contact-mobi .header-line a {
        color: #FFF;
    }

    .header-contact a .lg {
        font-size: 2vw;
        letter-spacing: 0.15rem;
        white-space: nowrap;
    }

    .header-contact a .sm {
        font-size: 1.7vw;
        padding-left: 0;
    }

    .header-phone .numm {
        font-size: 3.3vw;
        padding-top: 5px;
        padding-left: 39px;
        margin-bottom: 0;
        display: flex;
        align-items: center;
        letter-spacing: -0.1rem;
    }

    .header-phone .numm span {
        font-size: 2.5vw;
        font-weight: bold;
        display: inline-block;
        margin-right: 1vw;
        letter-spacing: .5px;
    }

    .header-contact a::after {
        width: 5vw;
        height: 5vw;
        bottom: 1.5vw;
        right: 3vw;
    }

    .header-contact a::before {
        width: 6vw;
        height: 6vw;
        left: -2.5vw
    }

    .header-phone .slogan {
        padding-left: 2vw;
        margin-bottom: 0;
    }

    .header-phone .slogan span {
        font-size: 1.6vw;
        margin-bottom: -3px;
        display: block;
    }

    .header-phone .numm::before {
        width: 20px;
        height: 20px;
        top: calc(50% - 8px);
        left: 10px;
    }

    .header-phone .slogan span::before,
    .header-phone .slogan span::after {
        width: 2vw;
    }

    .header-phone .slogan span::before {
        bottom: 1vw;
        right: -2vw;
    }

    .header-phone .slogan span::after {
        bottom: 1vw;
        left: -2.5vw;
    }

    .header-phone a {
        white-space: nowrap;
        display: flex;
        flex-direction: column;
        justify-content: center;
        align-items: center;
        text-align: center;
        margin-bottom: 0;
        padding-top: 3px;
    }

    #box-contact-mobi.test .header-phone .numm{
        color: #2c86cc;
    }

    #box-contact-mobi.test .header-phone .txt.space{
        margin: 7px 0 2px;
    }

    #box-contact-mobi.test .header-phone .txt{
        line-height: 1.2;
        font-weight: bold;
        font-size: 1.6vw;
    }


    #box-contact-pc {
        display: none !important;
    }

    .sec05-list li a p {
        font-size: 14px;
    }

    .header-phone .time {
        font-size: 1.6vw;
        padding-left: 3vw;
    }

    footer img,
    #header img,
    .to-top img {
        height: auto !important;
    }

    .sec05-list li a::after {
        width: 70px;
        height: 70px;
        right: 0 !important;
    }

    #header .contact-pc-phone {
        color: #FFF;
        margin-bottom: 10px;
        padding-right: 0;
    }

    #header .contact-pc-phone .numm a {
        font-size: 46px !important;
        font-weight: bold !important;
        display: inline-block;
        border-bottom: 0;
        padding: 0;
    }

    .contact-pc-phone .numm::before {
        background: url("../images/ic-tel-contact-sp.png") no-repeat center /cover;
    }

    .btn-line a {
        background: #06c755 !important;
    }

    .btn-contact a {
        background-color: #fad23c !important;
    }

    .btn-sp a {
        background-color: #2c86cc !important;
        padding-left: 20px !important;
    }

    #header .btn-primary a {
        display: flex;
        height: 60px;
    }

    .box_sp.bnrline {
        margin-top: 11px;
        margin-bottom: 0;
    }

    .to-top.lg {
        bottom: 200px !important;
        width: 60px;
        right: 0;
        height: auto;
    }

    .to-top.youtube {
        bottom: 110px !important;
        width: 131px;
        right: 0;
        height: auto;
    }

    .to-top.youtube.bnr_fix {
        bottom: 200px !important;
        width: 116px;
    }

    #box-contact-mobi.test .header-contact a{
        width: 100%;
        height: 100%;
        padding-top: 3px;
        padding-right: 0;
        padding-left: 7vw;
    }

    #box-contact-mobi.test .header-contact a:after{
        right: unset;
        left: 10vw;
        background: url("../images/ic-mail.png") no-repeat center /cover;
        height: 16px;
        width: 28px;
        bottom: 50%;
        transform: translateY(50%);
    }

    #box-contact-mobi.test .header-contact a::before{
        display: none;
    }

    #box-contact-mobi.test .header-contact a .lg{
        color: #fff;
        text-shadow: unset;
        font-weight: bold;
    }

    #box-contact-mobi.test .header-phone{
        width: 43.5% !important;
    }
    #box-contact-mobi.test .header-contact{
        width: 43.5% !important;
    }

    #box-contact-mobi.test .header-line{
        flex: 1;
        /*background: unset;*/
    }

    .footer-test.box_sp.to-top{
        max-width: unset !important;
        width: 88%;
        bottom: 60px !important;
        left: 0;
        right: 12%;
        /*transform: translateX(-50%);*/
    }

    .footer-test.ic-youtube.box_sp.to-top{
        max-width: unset !important;
        width: 12% !important;
        left: unset !important;
        right: 0vw !important;
        transform: unset !important;
        bottom: 60px;
        background: #ff7a59;
        height: 60px;
    }

    .footer-test.ic-youtube.box_sp.to-top a{
        display: flex;
        align-items: center;
        justify-content: center;
        height: 100%;
    }

    .footer-test.ic-youtube.box_sp.to-top img{
        position: unset !important;
    }

    .footer-test.ic-youtube.box_sp.to-top img{
        width: 45px;
    }

    /*========== END 750 ============== */

    .box_process_photo .process span.img{
        height: unset;
    }

    .campain.test{
        left: 0;
        right: 0;
        width: 100%;
        display: flex;
        align-items: center;
        justify-content: space-between;
        height: auto;
        bottom: 60px !important;
    }

    /*.campain.test .cp-sp{*/
    /*    width: 87%;*/
    /*}*/

    .campain.test .cp-ytb{
        width: 13%;
        min-width: 13%;
        background: #ff7a59;
        height: 100%;
        margin-bottom: -12px;
    }

    .campain.test .cp-ytb .ytb-btn{
        display: flex;
        align-items: center;
        justify-content: center;
        width: 100%;
        height: 100%;
        overflow: hidden;
    }

    .campain.test .cp-ytb .ytb-btn img{
        position: unset !important;
        object-fit: none;
    }

    .cp-sp{
        position: relative;
        transform: unset;
    }
    .mv_video{
        height: 100vh;
    }
	.mv_txt {
  top: 50%;
		bottom: inherit;
}
    .mv_txt h2 {
        font-size: 6.5vw;
        line-height: 9vw;
 
        margin-bottom: 2vw;
        letter-spacing: 0.2vw;
      }
      .sec01_mv {
        padding: 30px 0 0 0;
        display: block;
      }
      .box01-list {
        flex-wrap: wrap;
        max-width: 360px;
        justify-content: center;
        align-items: center;
        margin: 0 auto;
      }
      .box01-list li {
        margin-bottom: 20px;
        width: calc(50% - 20px);
        height: auto;
      }
      .box01-list li:not(:nth-child(2n)) {
        margin-right: 20px;
      }
      .catch_tt {
        font-size: 3vw;
        letter-spacing: 0em;
        line-height: 4vw;
  
      }
    .idx_exterior {
        padding: 10vw 4vw;
    }
    .idx_exterior .sec09-banner02 a{
        position: relative;
        font-size: 16px;
        height: 50px;
        margin: -2vw auto 0;
        max-width: 240px;
    }
}

@media screen and (max-width: 640px) {

    #box-contact-mobi.test .header-contact a{
        /*padding-left: 10vw;*/
    }

    #box-contact-mobi.test .header-phone .numm .key{
        font-size: 3vw;
    }

    #box-contact-mobi.test .header-phone .txt{
        font-size: 2vw;
    }

    .box-640 {
        display: block !important;
    }

    .sec02-h3,
    .big40 {
        font-size: 5vw;
    }

    .big50 {
        font-size: 7vw;
    }

    .sec05-h3 {
        font-size: 22px;
    }

    .sec05-h3 span {
        font-size: 25px;
    }

    .sec05-list li .tt {
        font-size: 15px;
        white-space: nowrap;
    }

    .sec08-btn {
        flex-direction: column;
    }

    .sec08-btn .btn-primary:not(:last-child) {
        margin-right: 0 !important;
        margin-bottom: 20px !important;
    }

    .sec08-btn .btn-primary a {
        width: 290px;
    }

    .grecaptcha-badge {
        bottom: 120px !important;
        z-index: 9999;
    }
    table.tb_block td .col2 {
        flex-direction: column;
        gap: 1px;
    }	
    .campain.test .cp-ytb{

        margin-bottom: -11px;
    }

}

/* screen-max:640px */

@media screen and (max-width: 560px) {

    #box-contact-mobi.test .header-contact a{
        padding-left: 6vw;
    }

    #box-contact-mobi.test .header-contact a:after{
        left: 7vw;
    }

    .cp-sp{
        transform: unset;
    }

    #box-contact-mobi.test .header-phone .numm .key{
        font-size: 4vw;
    }

    #box-contact-mobi.test .header-phone .txt.space{
        margin: 3px 0 2px;
    }

    #box-contact-mobi.test .header-phone .txt{
        font-size: 2vw;
    }

    .box-560 {
        display: block !important;
    }

    .list-news li {
        flex-direction: column;
        align-items: flex-start;
    }

    .box-list-news .inner {
        height: 80px;
    }

    .list-news-tt {
        width: 120px;
        font-size: 13px;
    }

    .list-news {
        width: calc(100% - 120px);
    }

    .sec01-title {
        margin-bottom: 32vw;
    }

    .sec01-logo {
        position: relative;
        justify-content: space-between;
    }

    .sec01-logo > p:nth-of-type(2) {
        position: absolute;
        top: -30vw;
        left: calc(50% - 20vw);
    }

    .sec01-logo > p img {
        width: 40vw;
    }

    .sec03-item {
        flex-direction: column;
    }

    .sec03-item-img {
        display: block;
        margin: 0 auto 30px auto !important;
        width: 100%;
        max-width: 280px;
        order: 1;
    }

    .sec03-item-content {
        order: 2;
    }

    .sec03-item .title {
        font-size: 20px
    }

    .sec03-item-orange .title {
        font-size: 17px
    }

    .sec03-item-content .btn-primary a {
        margin: 0 auto;
    }

    .sec03-list .sec03-item:not(:last-child) {
        margin-bottom: 60px;
    }

    .sec03-item .sec03-item-content {
        padding-top: 0 !important;
    }

    .sec03-item-orange .sec03-item-content::before {
        bottom: 58px;
        right: 5px;
    }

    .btn-primary.big a {
        width: 300px;
        height: 60px;
    }

    .sec05-list li {
        width: 100%;
    }

    .sec05-list li .tt {
        font-size: 20px;
    }

    .sec06-h3 {
        font-size: 6vw !important;
    }

    .sec06-slogan span {
        font-size: 3vw;
    }

    .sec07-h3 {
        font-size: 4.2vw;
    }

    .sec07-list-bnn dl dd {
        flex-wrap: wrap;
    }

    .sec07-list-bnn dl .title {
        width: 100%;
        margin-bottom: 3vw !important;
    }

    .sec07-list-bnn dl {
        height: 25vw;
    }

    .sec07-list-bnn dl dt {
        padding: 5px 3vw 5px 2vw;
    }

    .sec07-list-bnn dl dd {
        padding: 10px 5vw;
    }

    .sec07-list-bnn dl .durability .key {
        width: 22vw;
        height: 5.5vw;
    }

    .sec07-list-bnn dl .durability {
        margin-right: auto;
    }

    .sec07-des {
        font-size: 14px;
    }

    .sec07-list-bnn dl .title .lg {
        font-size: 5.2vw;
    }

    .sec07-list-bnn dl .title .sm {
        font-size: 3.2vw;
    }

    .sec07-list-bnn dl dt {
        font-size: 4.1vw;
    }

    .sec07-list-bnn dl .durability .key {
        font-size: 2.5vw;
    }

    .sec07-list-bnn dl .durability .val {
        font-size: 6vw;
    }

    .sec07-list-bnn dl .money .numm {
        font-size: 9.1vw;
    }

    .sec07-list-bnn dl .money .numm .sm {
        font-size: 7vw;
    }

    .sec07-list-bnn dl .money .val .lg {
        font-size: 4vw;
    }

    .sec07-list-bnn dl .money .val {
        font-size: 2.5vw;
    }

    .sec07-list-bnn dl .box-money .vat {
        font-size: 3.5vw;
    }

    .sec07-list-bnn dl {
        width: 92vw;
        height: 36vw;
    }

    .sec08-image {
        margin-bottom: 70px;
    }

    .sec09-banner-tt {
        font-size: 4.5vw;
    }

    .sec09-group-btn {
        flex-direction: column;
    }

    .sec09-group-btn .btn-primary:not(:last-child) {
        margin-right: 0;
        margin-bottom: 20px;
    }

    .header-contact a .lg {
        font-size: 2.5vw;
    }

    .header-contact a .sm {
        font-size: 2vw;
    }

    .header-contact a::before {
        width: 7vw;
        height: 7vw;
        left: -3.5vw;
        top: 0;
    }

    .header-contact a::after {
        right: 2vw;
    }

    .header-phone .slogan span {
        font-size: 2.2vw;
        letter-spacing: 0.02rem;
    }

    #box-contact-mobi .header-phone {
        padding-right: 3vw;
    }

    .header-phone .time {
        font-size: 1.8vw;
    }

    .header-phone .slogan span::before {
        right: -1.5vw;
    }

    .box_sp.bnrline {
        width: 150px;
    }
}

/* screen-max:560px */

@media screen and (max-width: 520px) {

    .footer-test.box_sp.to-top{
        max-width: 320px;
    }

    /* .bnrline {
        display: none;
    } */

    .box-520 {
        display: block !important;
    }

    .heacer-construction {
        width: 100px;
    }

    .sec04-list {
        flex-direction: column;
        align-items: center;
    }

    .sec04-list dl {
        width: 100%;
        max-width: 368px;
    }

    .sec04-list dl:not(:last-child) {
        margin-bottom: 40px;
    }

    .sec04-slogan {
        font-size: 5vw;
    }

    .sec04-slogan > span::after {
        top: 15px;
        right: -8vw;
        width: 33px;
        height: 44px;
    }

    .sec04-slogan > span::before {
        left: -30vw;
        top: 15px;
        width: 33px;
        height: 43px;
    }

}

/* screen-max:520px */

@media screen and (max-width: 460px) {

    .campain.test{
        bottom: 45px !important;
        height: 38px;
        /*background: #404040;*/
    }

    #box-contact-mobi.test .header-phone .txt{
        font-size: 2.2vw;
    }

    .footer-test.box_sp.to-top{
        bottom: 55px !important;
        left: 41%;
    }

    #box-contact-mobi.test{
        height: 45px;
    }

    #box-contact-mobi.test .header-phone, #box-contact-mobi.test .header-contact{
        width: 43%;
    }

    #box-contact-mobi.test .header-contact a:after{
        left: 5vw;
    }

    .box-460 {
        display: block !important;
    }

    .box-banner-top .tt01,
    .box-banner-top .tt03 {
        font-size: 5vw;
    }

    .box-banner-top .tt02 {
        width: 75vw;
    }

    .sec04-h3 {
        font-size: 25px;
    }

    .sec06-btn a::before {
        right: 15px;
    }

    .sec06-btn a {
        width: 300px;
        font-size: 17px;
        padding-bottom: 2px;
    }

    .sec09-h3 .sm::before {
        display: none;
    }

    .sec09-h3 .lg::before {
        display: none;
    }

    .header-phone a {
        padding-top: 7px;
    }

    .header-phone .time {
        font-size: 2.5vw
    }

    .header-phone .slogan {
        margin-bottom: 1vw;
    }

    .header-contact a .sm {
        font-size: 2.5vw;
    }

    .box_image_modify .img-col {
        flex-direction: column;
        gap: 50px;
    }

    .box_process_photo .process {
        flex-direction: column;
        gap: 10px;
    }

    .box_process_photo .process p{
        width: 100%;
    }

    .box_process_photo .process span.txt{
        width: 100%
    }

    .box_image_modify .img-col:before {
        transform: translate(-50%, 50%) rotate(180deg)
    }
}

/* screen-max:460px */

@media screen and (max-width: 420px) {
    .box-420 {
        display: block !important;
    }

    .h-information .logo {
        width: 140px;
    }

/*
    .hamburger {
        width: 50px;
        padding-left: 8px;
    }
*/

    .heacer-construction {
        /* margin-right: 47px; */
    }

    .box-rating .txt a {
        font-size: 10px;
    }

    .sec03-item .title {
        font-size: 17px;
        white-space: nowrap;
    }

    .sec03-item-orange .title {
        font-size: 15px;
    }

    .banner-top-map .btn-primary a {
        width: 280px;
    }

    .sec09-phone .phone {
        font-size: 37px;
    }

    .sec09-phone .time {
        font-size: 11px;
    }

    .sec09-phone .phone:before {
        top: 5px;
        left: -32px;
    }

    .ft-bnn-list {
        flex-wrap: wrap;
        margin: 0 -5px;
    }

    .ft-bnn-list p {
        margin: 0 5px 20px !important;
    }

    .ft-bnn-list p:nth-of-type(1) {
        order: 1;
        /* margin-bottom: 20px; */
    }

    .ft-bnn-list p:nth-of-type(2) {
        order: 3;
    }

    .ft-bnn-list p:nth-of-type(3) {
        order: 2;
        /* margin-bottom: 20px;
        margin-right: 0; */
    }

    .ft-bnn-list p:nth-of-type(4) {
        order: 4;
        width: 57.7vw;
        height: 19vw;
        font-size: 4vw;
    }

    .ft-bnn-list p:nth-of-type(1) img {
        width: 24vw;
    }

    .ft-bnn-list p:nth-of-type(2) img {
        width: 26.2vw;
    }

    .ft-bnn-list p:nth-of-type(3) img {
        width: 60vw;
    }

    .header-phone .numm {
        font-size: 4vw;
        letter-spacing: -0.15rem;
        padding-left: 32px;
    }

    #header .contact-pc-phone .numm a {
        font-size: 39px !important;
    }

    #header .contact-pc-phone .numm::before {
        width: 30px;
        height: 30px;
        top: calc(50% - 10px);
    }

    .header-phone .numm::before {
        width: 16px;
        height: 16px;
        top: calc(50% - 8px);
    }

    .bnnt_or {
        order: 5;
        margin-top: 20px;
    }
    .box01-list {
        max-width: 300px;
      }
      .popup_box p{
        left: -15px;
        right: unset;
      }
}


/* screen-max:420px */

@media screen and (max-width: 360px) {

    #box-contact-mobi.test .header-contact a:after{
        left: 3vw;
    }

    .footer-test.box_sp.to-top{
        bottom: 55px !important;
        left: 41%;
        max-width: 250px;
    }

    .box-360 {
        display: block !important;
    }

    .sec01-sub {
        font-size: 9px;
        max-width: 280px;
    }

    .sec04-h3 {
        font-size: 21px;
    }

    .sec03-item .title {
        font-size: 15px;
        white-space: nowrap;
    }

    .sec03-item-orange .title {
        font-size: 13px;
    }

    .sec05-list li .tt {
        font-size: 17px;
    }

    .sec06-btn a {
        width: 280px;
        font-size: 16px;
    }

    .sec07-h3 {
        font-size: 4vw;
    }

    .sec09-h3 .lg::before {
        right: 0vw;
    }

    .idx-copy-right p {
        font-size: 12px;
    }

    #box-contact-mobi .header-line {
        font-size: 12px;
        width: 25vw;
    }

    #box-contact-mobi .header-contact {
        width: 38vw;
    }

    .header-contact a .lg {
        font-size: 3vw;
        padding-left: 1.5vw;
    }

}

/* screen-max:360px */

@media (-ms-high-contrast: none),
(-ms-high-contrast: active) {
}

/* IE */

@supports (-ms-ime-align: auto) {
}

/* EGDE */

@media screen and (max-width: 750px) {
    #wrap-slider .slick-dots li {
        margin-bottom: 2vw;
    }
    #wrap-slider{
        padding-top: 60px;
    }
    .box_sp.logoleft {
display: flex;
justify-content: space-between;
align-items: center;
width: calc( 100% - 60px );
min-height: 60px;
box-sizing: border-box;
padding: 0 10px;
    }
    .box_sp.logoleft a.lg {
width: clamp(160px, 43vw, 190px);
margin-right: 0;
display: flex;
align-items: center;
            }
    .h-infomation-box {
width: 100%;
            }
    .box_sp.logoleft a.lg img {
width: 100%;
height: auto;
display: block;
            }
    .box_sp.logoleft .bnrline {
margin: 0 0 0 auto;
            }
    .box_sp.logoleft .bnrline a {
display: flex;
align-items: center;
justify-content: center;
            }
    .box_sp.logoleft .bnrline img.second_img {
width: 54px;
height: 54px;
display: block;
            }
            .heacer-construction{
                margin-top: 8px;
            }
            .box-header.idx-fixed.active .box_sp.logoleft{
                    display: none;
            }
}
@media screen and (max-width: 375px) {
    .box_sp.logoleft a.lg {
        width: clamp(145px, 43vw, 165px);
        margin-right: 0;
                    }
    .box_sp.logoleft .bnrline img.second_img {
        width: 50px;
        height: 50px;
                    }
}


/* 240618 start*/

@media screen and (min-width: 769px) {
.zsiq-flexM {
    bottom: 160px!important;
    right: 15px;
  }
  .zsiq-float-tooltip{
    height: 80px!important;
  }
  .footer-test.to-top.youtube.bnr_fix{
    bottom: 265px;
  }
  .footer-test.to-top.google.bnr_fix{
    bottom: 420px;
    width: fit-content;
    height: auto;
    right: 10px;
  }
  .footer-test.to-top.youtube{
    bottom: 250px;
  }
  .chat-iframe-wrap{
    right: 80px!important;
  }
  .zsiq-flexM{
    opacity:0;
    transition:0.2s;
  }
  .zsiq-flexM.show{
    opacity:1;
  }
  p.zsiq-elips{
    font-size: 13px;
    line-height: 1.6;
    overflow: visible;
    text-overflow: clip;
    white-space: normal;
  }
}
@media screen and (min-width: 1520px) {
  .footer-test.to-top.youtube.bnr_fix{
    bottom: 265px;
  }
}


@media screen and (max-width: 768px) {
.zsiq-flexM {
    bottom: auto!important;
    top: 70px;
    right: 0px!important;
    opacity:0;
    transition:0.2s;
  }
  .zsiq-flexM.show{
    opacity:1;
  }
  .zsiq-flexM.none{
    display: none;
  }


}



@media screen and (max-width: 750px) {
    #box-contact-mobi .header-line a{
      width: 100%;
      height: 100%;
      display: flex;
      justify-content: center;
      align-items: center;
      position: relative;
    }

.seasonal-float-img {
    position: absolute;
    bottom: 200px !important;
}



}

@media screen and (max-width: 480px) {
  .sec09-inner > div {
    margin-bottom: 0;
  }
  #sec09 {
    padding: 70px 0 35px;
  }
}

/* 240618 end*/
