@charset "utf-8";

/* CSS Document */

/*-------------------------
- mv
-
-------------------------*/



/*=======================================
　共通
=======================================*/
.txt01 {
	line-height: 2;
	margin-bottom: 40px;
	text-align: justify;
}
@media only screen and (max-width: 767px){
.txt01 {
	/* margin-bottom: 20px; */
}
}



.btn01 a {
	min-width: calc(311px - 6em - 4.5em);
}
@media only screen and (max-width: 767px){
.btn01 a {
	min-width: calc(100%  - 6em - 4.5em);
}
}



.copy_red {
	position: absolute;
	top: 0;
	left: 0;
}
.copy_red span {
	/* font-size: 45px; */
	font-size: calc(45/1600*100vw);
	font-weight: 700;
	color: var(--main_color);
	letter-spacing: 0.1em;
	border: 1px solid #707070;
	padding: 12px 0.3em 16px 0.4em;
	display: inline-block;
	background: #fff;
}
.copy_red span:not(:last-child) {
	margin-bottom: 10px;
}
@media only screen and (min-width: 1600px){
.copy_red span {
	font-size: 45px;
}
}
@media only screen and (max-width: 767px){
.copy_red {
	position: relative;
	margin-bottom: 30px;
}
.copy_red span {
	/* font-size: 22.5px; */
	font-size: calc(36.3/750*100vw);
	padding: 6px 0.3em 8px 0.4em;
}
.copy_red span:not(:last-child) {
	margin-bottom: 10px;
}
}



.copy_big {
	font-size: calc(60/1600*100vw);
	font-weight: 700;
	letter-spacing: 0.1em;
	margin-bottom: 40px;
	line-height: 1.3333;
}
@media only screen and (min-width: 1600px){
.copy_big {
	font-size: 60px;
}
}
@media only screen and (max-width: 767px){
.copy_big {
	font-size: 20px;
	margin-bottom: 20px;
}
}



.webp .bg_img {
    background: url("../images/top/bg01.webp") no-repeat center top;
    background-size: cover;
}
.no-webp .bg_img {
    background: url(../images/top/bg01.jpg) no-repeat center top;
    background-size: cover;
}
@media only screen and (max-width: 767px){
.bg_img {
}
}



/*=======================================
　mv_01 CM未放送期間
=======================================*/
.mv_01 {
    height: 57.69vw;
    position: relative;
}
.webp .mv_01 {
    background: url("../images/top/mv01_bg.webp") no-repeat center top;
    background-size: cover;
}
.no-webp .mv_01 {
    background: url("../images/top/mv01_bg.jpg") no-repeat center top;
    background-size: cover;
}
.mv_01 a {
    display: block;
}
.mv_01 .mv_ttl {
    position: absolute;
    width: 86.995625%;
    top: 1.86vw;
    left: 50%;
    -webkit-transform: translateX(-50%);
    transform : translateX(-50%);
}
.mv_01 .mv_bnr {
    width: 37.81%;
    bottom: 1.2vw;
    left: 6.53%;
}
.mv_01 .mv_pic {
	position: absolute;
	width: 24.4375%;
	bottom: 0;
	left: 0.69%;
}
.mv_01 .mv_content_inn {
	position: absolute;
	width: 72.993125%;
	top: 15.26vw;
	left: 20.25%;
}
.mv_01 .mv_content_inn > .copy {
	font-weight: 700;
	font-size: calc(54/1600*100vw);
	letter-spacing: 0.1em;
	line-height: 1.259;
	margin-bottom: 1.5vw;
}
.mv_01 .mv_content_inn > .flex_area {
	justify-content: space-between;
	align-items: center;
}
.mv_01 .mv_content_inn .flex_area .mv_plan {
	width: 62.1%;
}
.mv_01 .mv_content_inn .flex_area .mv_plan ul.flex_area {
	flex-flow: wrap;
	justify-content: space-between;
	gap: 1.16vw 0;
}
.mv_01 .mv_content_inn .flex_area .mv_plan ul.flex_area li {
	width: 48.66%;
}
.mv_01 .mv_content_inn .flex_area .mv_plan p.notes {
	font-weight: 400;
	font-size: calc(14/1600*100vw);
	letter-spacing: 0.08em;
	line-height: 1.928;
	margin-left: 3.57%;
	white-space: nowrap;
}
.mv_01 .mv_content_inn .flex_area .mv_movie {
	width: 33.46%;
}
.mv_01 .mv_content_inn .flex_area .mv_movie .copy {
	margin-bottom: 1.47vw;
}
.mv_01 .mv_content_inn .flex_area .mv_movie iframe {
	width: 100%;
	height: 13.95vw;
	-webkit-filter: drop-shadow(10px 10px 10px rgb(0 0 0 / 16%));
	-moz-filter:drop-shadow(10px 10px 10px rgb(0 0 0 / 16%));
	-ms-filter:drop-shadow(10px 10px 10px rgb(0 0 0 / 16%));
	filter:drop-shadow(10px 10px 10px rgb(0 0 0 / 16%));
	border: 3px solid #707070;
}
.mv_01 .mv_content_inn .flex_area .mv_movie .player {
	max-width: 100%!important;
}
@media only screen and (max-width: 767px){
.mv_01 {
    height: auto;
}
.webp .mv_01 {
    background: url("../images/top/mv01_bg_sp.webp") no-repeat center top;
    background-size: cover;
}
.no-webp .mv_01 {
    background: url("../images/top/mv01_bg_sp.jpg") no-repeat center top;
    background-size: cover;
}
.mv_01 .mv_ttl {
    width: 91.86%;
    position: static;
    -webkit-transform: translateX(0);
    transform: translateX(0);
    margin: 0 auto 4.4vw;
}
.mv_01 .mv_pic {
	width: 32.8%;
	left: 0;
}
.mv_01 .mv_content_inn {
	position: static;
	width: 90%;
	margin: 0 auto;
}
.mv_01 .mv_content_inn > .copy {
	font-size: calc(26/750*100vw);
	margin-bottom: 0;
	position: absolute;
	writing-mode: vertical-rl;
	left: 9.33%;
	line-height: 1.4;
}
.mv_01 .mv_content_inn > .copy span {
	transform: translateX(0.2em);
	display: inline-block;
}
.mv_01 .mv_content_inn > .flex_area {
	width: 78.02%;
	margin-left: auto;
	padding-bottom: 11.47vw;
}
.mv_01 .mv_content_inn .flex_area .mv_plan {
	width: 100%;
	margin-bottom: 4.4vw;
}
.mv_01 .mv_content_inn .flex_area .mv_plan ul.flex_area {
	display: flex;
}
.mv_01 .mv_content_inn .flex_area .mv_plan ul.flex_area li {
	width: 48.66%;
}
.mv_01 .mv_content_inn .flex_area .mv_plan p.notes {
	font-size: calc(12/750*100vw);
	margin-left: 5%;
	line-height: 1.666;
	white-space: normal;
}
.mv_01 .mv_content_inn .flex_area .mv_movie {
	width: 84.58%;
	margin-left: auto;
}
.mv_01 .mv_content_inn .flex_area .mv_movie .copy {
	margin-bottom: 1.47vw;
}
.mv_01 .mv_content_inn .flex_area .mv_movie iframe {
	width: 100%;
	height: 34.2vw;
	-webkit-filter: drop-shadow(5px 5px 5px rgb(0 0 0 / 16%));
	-moz-filter:drop-shadow(5px 5px 5px rgb(0 0 0 / 16%));
	-ms-filter:drop-shadow(5px 5px 5px rgb(0 0 0 / 16%));
	filter:drop-shadow(5px 5px 5px rgb(0 0 0 / 16%));
}
.mv_01 .mv_content_inn .flex_area .mv_movie .player {
	max-width: 100%!important;
}
}



/*=======================================
　mv_02 CM放送期間
=======================================*/
.mv_02 {
    /*height: 57.69vw;*/
    /* position: relative; */
    margin-bottom: 96px;
}
.mv_02 .caption {
	display: flex;
	justify-content: center;
	font-size: 12px;
	padding: 20px;
	text-align: center;
}
/*.webp .mv_02 {
    background: url("../images/top/mv02_bg.webp") no-repeat center top;
    background-size: cover;
}
.no-webp .mv_02 {
    background: url("../images/top/mv02_bg.jpg") no-repeat center top;
    background-size: cover;
}
.mv_02 div {
    display: block;
    position: absolute;
}
.mv_02 a {
    display: block;
}
.mv_02 .mv_ttl {
    width: 63.625%;
    top: 2.5vw;
    left: 5.44%;
}
.mv_02 .mv_point {
    width: 38.56%;
    bottom: 18.88vw;
    left: 6.53%;
}
.mv_02 .mv_bnr {
    width: 37.81%;
    bottom: 1.2vw;
    left: 6.53%;
}*/
@media only screen and (max-width: 767px){
.mv_02 {
    /*height: 136.13vw;*/
    margin-bottom: 0;
}
.mv_02 .caption {
	justify-content: flex-start;
	padding: 10px 10px 0 calc(10px + 1em);
	text-align: left;
	width: 100%;
	text-indent: -1em;
}
/*.webp .mv_02 {
    background: url("../images/top/mv02_bg_sp.webp") no-repeat center top;
    background-size: cover;
}
.no-webp .mv_02 {
    background: url("../images/top/mv02_bg_sp.jpg") no-repeat center top;
    background-size: cover;
}
.mv_02 div {
    display: block;
    position: absolute;
}
.mv_02 a {
    display: block;
}
.mv_02 .mv_ttl {
    width: 91.86%;
    top: 3.5vw;
    left: 5%;
}
.mv_02 .mv_point {
    width: 57.62%;
    bottom: 48.27vw;
    left: 5%;
}
.mv_02 .mv_bnr {
    width: 90%;
    bottom: 3.83vw;
    right: auto;
    left: 50%;
    -webkit-transform: translateX(-50%);
    transform: translateX(-50%);
}
.mv_02 .mv_pic {
    width: 46.26%;
    bottom: -4px;
    right: 0;
}*/
}

/*=======================================
　MV下電話番号
=======================================*/


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

	.mv_cv .h_tel_sp {
        padding: 0;
        margin: 30px auto 40px;
        width: 90%;
	}
	
	.mv_cv .h_tel_sp a {
        display: block;
        text-align: center;
    }


}


	
	
/*=======================================
　sec_intro
=======================================*/
.sec_intro {
	margin-bottom: 193px;
}
.sec_intro .balloon {
	margin-bottom: 130px;
}
.sec_intro .flex_area {
	justify-content: space-between;
}
.sec_intro .txt_area {
	width: 47.41%;
}
.sec_intro .txt_area .copy {
	font-size: calc(43/1600*100vw);
	font-weight: 700;
	letter-spacing: 0.15em;
	line-height: 1.5813;
	margin-bottom: 40px;
}
.sec_intro .img_area {
	width: 43.16%;
}
@media only screen and (min-width: 1600px){
.sec_intro .txt_area .copy {
	font-size: 43px;
}
}
@media only screen and (max-width: 767px){
.sec_intro {

	margin-bottom: 96.5px;
}
.sec_intro .balloon {
	margin-bottom: 20px;
}
.sec_intro .flex_area {display: flex;flex-direction: column-reverse;}
.sec_intro .txt_area {
	width: 100%;
}
.sec_intro .txt_area .copy {
	font-size: 21.5px;
	margin-bottom: 20px;
}
.sec_intro .img_area {
	width: 80%;
	margin: 0 auto 40px;
}
}



/*=======================================
　sec_point
=======================================*/
.sec_point {
	margin-bottom: 196px;
}
.sec_point .balloon {
	margin-bottom: 112px;
}
.sec_point .item {
	position: relative;
	align-items: flex-end;
	/* margin-bottom: 70px; */
	justify-content: space-between;
}
.sec_point .item_wrap:not(:last-child) {
	margin-bottom: 120px;
}
.sec_point .item .txt_area {
	/* padding-top: 500px; */
	position: relative;
}
.sec_point .item .txt_area .copy_red {
	margin-bottom: 85px;
	position: absolute;
	top: 0;
	left: 0;
}
.sec_point .item .txt_area .txt01 {
	/* width: 79.6%; */
	width: 84%;
	max-width: 480px;
	/* margin-bottom: 0; */
}
.sec_point .item_wrap:nth-child(1) .txt_area .txt01 {
	margin-bottom: 45px;
}
.sec_point .item_wrap:nth-child(2) .txt_area .txt01 {
	margin-bottom: 53px;
}
.sec_point .item .img_area {
	margin-top: 50px;
	width: 45.44%;
}
@media only screen and (max-width: 1000px){
.sec_point .item .txt_area .txt01 {
	margin-top: 20vw;
}
}
@media only screen and (max-width: 767px){
.sec_point {
	margin-bottom: 98px;
}
.sec_point .balloon {
	margin-bottom: 30px;
}
.sec_point .item {
	margin-bottom: 35px;
}
.sec_point .item_wrap:not(:last-child) {
	margin-bottom: 120px;
}
.sec_point .item .txt_area {margin-bottom: 30px;}
.sec_point .item .txt_area .copy_red {
	margin-bottom: 85px;
	position: absolute;
	top: 0;
	left: 0;
}
.sec_point .item .txt_area .txt01 {
	width: 100%;
	margin-top: 0;
}
.sec_point .item_wrap:nth-child(1) .txt_area .txt01 {
	margin-bottom: 25px;
}
.sec_point .item .img_area {
	margin-top: 0;
}
.sec_point .item .img_area {
	width: 100%;
}
}



/*=======================================
　sec_guarantee
=======================================*/
.sec_guarantee {
	margin-bottom: 132px;
}
.sec_guarantee .balloon {
	margin-bottom: 140px;
}
.sec_guarantee .inner {
	position: relative;
}
.sec_guarantee .inner .copy_red {
	right: 2%;
	left: auto;
	text-align: right;
	top: 20px;
}
.sec_guarantee .inner .flex_area {
	justify-content: space-between;
	margin-bottom: 127px;
	/*! align-items: flex-end; */
	position: relative;
	/*! top: -50px; */
	margin-bottom: 70px;
	margin-top: -50px;
}
.sec_guarantee .inner .left {
	/*! margin-top: 43.6px; */
	width: 45.44%;
	/*! position: relative; */
	/*! top: 15%; */
}
.sec_guarantee .inner .left .box_r {
	font-size: 25px;
	line-height: 1.28;
	color: var(--main_color);
	border: 2px solid var(--main_color);
	padding: 15px 4.5%;
	display: inline-block;
}
.sec_guarantee .inner .left .img {
	margin-bottom: 43px;
	margin-top: 34%;
}
.sec_guarantee .inner .right {
	/* width: 39.56%; */
	width: 39.7%;
	margin: 245px 5.62% 0 0;
	top: 0;
	position: relative;
}
.sec_guarantee .inner .right .txt01 {
	margin-bottom: 20px;
	font-size: 18px;
}
.sec_guarantee .btn01 {
	margin: 0 auto;
}
@media only screen and (min-width: 1600px){
.sec_guarantee .inner .left .box_r {
	font-size: 25px;
}
}
@media only screen and (max-width: 1120px){
	.sec_guarantee .inner .left .box_r {
		font-size: calc(23/1174*100vw);
	}
}
@media only screen and (max-width: 767px){
.sec_guarantee {
	margin-bottom: 66px;
}
.sec_guarantee .balloon {
	margin-bottom: 20px;
}
.sec_guarantee .inner {
	position: relative;
}
.sec_guarantee .inner .copy_red {
	right: 0;
	left: auto;
}
.sec_guarantee .inner .flex_area {
	margin-bottom: 63.5px;
}
.sec_guarantee .inner .left {
	margin: 0 auto 50px;
	width: 100%;
}
.sec_guarantee .inner .left .box_r {
	font-size: 16px;
	padding: 7.5px 2.5%;
}
.sec_guarantee .inner .left .img {
	margin-bottom: 21.5px;
	margin-top: 26%;

}
.sec_guarantee .inner .right {
	width: 100%;
	margin: 0;
}
.sec_guarantee .inner .right .txt01 {
	margin-bottom: 25px;
	font-size: 13px;
}
.sec_guarantee .btn01 {
	margin: 0 auto;
}

}



/*=======================================
　sec_about
=======================================*/
.sec_about {
	margin: 194px 0 120px;
	padding: 76px 0 0;
	position: relative;
}
.sec_about > .img {
	position: absolute;
	width: 30.25%;
	left: 12.44%;
	bottom: -4px;
	/* margin-bottom: 109px; */

	max-width: 484px;
}
.sec_about .inner {
	justify-content: space-between;
	align-items: end;
}
.sec_about .left {
	/*width: 56.69%;*/
}
.sec_about .img {
	width: 43.21%;
	transform: translateY(4px);
}
.sec_about .right {
	width: 49.82%;
}
.sec_about .right .copy_big {
	text-align: left;
	margin-bottom: 60px;
}
.sec_about .right .nav_box {
	overflow: hidden;
	max-height: 101px;
	height: 9.02vw;
	border-radius: 15px;
}
.sec_about .right .nav_box {
	margin-bottom: 2.68vw;
}
.sec_about .right .nav_box img {
	transition: 0.2s all;
	object-fit: cover;
	max-height: 101px;
	height: 9.02vw;
}
.sec_about .right .nav_box:hover img {
	transform: scale(1.1);
}
.sec_about .right .nav_box a {
	position: relative;
	display: block;
}
.sec_about .right .nav_box a:hover {
	opacity: 1;
}
.sec_about .right .nav_box span {
	position: absolute;
	top: 50%;
	-webkit-transform : translateY(-50%);
	transform : translateY(-50%);
	left: 0;
	font-size: calc(23/1600*100vw);
	color: #fff;
	font-weight: 700;
	display: block;
	width: 100%;
	padding: 0 3.5em 0 1.5em;
}
.sec_about .right .nav_box span::after {
    content: "";
    position: absolute;
    background: url("../images/common/arrow02.png") no-repeat;
    background-size: cover;
    top: 54%;
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
    right: 1.5em;
    width: 40px;
    height: 41px;
}
@media only screen and (min-width: 1600px){
.sec_about .right .nav_box:not(:last-child) {
	margin-bottom: 30px;
}
.sec_about .right .nav_box span {
	font-size: 23px;
}
}
@media only screen and (max-width: 767px){
.sec_about {
	margin: 97px 0 60px;
	/* padding: 38px 0 54.5px; */
	/* display: flex; */
	/* flex-direction: column-reverse; */
}
.sec_about > .img {
	position: relative;
	width: 45%;
	left: 5%;
	top: 4px;
}
.sec_about .inner {/* margin-bottom: 30px; */display: flex;flex-direction: column-reverse;}
.sec_about .left {
	/* width: 80%; */
}
.sec_about .right {
	width: 100%;
}
.sec_about .right .copy_big {
	margin-bottom: 30px;
}
.sec_about .right .nav_box {
	height: 70px;
	border-radius: 7.5px;
}
.sec_about .right .nav_box:not(:last-child) {
	margin-bottom: 15px;
}
.sec_about .right .nav_box img {
	height: 70px;
}
.sec_about .right .nav_box:hover img {
	transform: scale(1.1);
}
.sec_about .right .nav_box a {
}
.sec_about .right .nav_box a:hover {
	opacity: 1;
}
.sec_about .right .nav_box span {
	font-size: 15px;
	padding: 0 3.5em 0 1.5em;
}
.sec_about .right .nav_box span::after {
    width: 30px;
    height: 30px;
}
}



/*=======================================
　sec_case
=======================================*/
.sec_case {
    margin-bottom: 161px;
}
.sec_case h3 {
 	font-size: 60px;
	color: #fff;
	letter-spacing: 0.1em;
	margin-bottom: 30px;
}
.sec_case .txt01 {
 	color: #fff;
}
@media only screen and (max-width: 767px){
.sec_case {
    margin-bottom: 80.5px;
}
.sec_case h3 {
 	font-size: 30px;
 	margin-bottom: 5px;
}
.sec_case .txt01 {
	margin-bottom: 10px;
	/* font-size: 10px; */
}
.sec_case .btn01 {
	width: fit-content;
}
}



/* 2023/8/28改定
--------------------------------------------------------- */
/*=======================================
　sec_cp_bnr
=======================================*/
.sec_cp_bnr {
	margin-bottom: calc(104.2px - 5.89vw);
	/* transform: translateY(-66px); */
	transform: translateY(-4.89vw);
}
@media only screen and (max-width: 767px){
.sec_cp_bnr {
	margin-bottom: 52.1px;
	transform: translateY(-5.89vw);
}
}



/*=======================================
　sec_plan_box
=======================================*/
.sec_plan_box .inner {
	max-width: inherit;
}
.sec_plan_box .copy_area {
	display:-webkit-box;
	display:-webkit-flex;
	display:-ms-flexbox;
	display: flex;
	align-items: flex-end;
	justify-content: center;
	max-width: 1138.25px;
	margin: 0 auto 79.3px;
}
.sec_plan_box .copy_area .pic {
	max-width: 355px;
	width: 31.69%;
}
/*.sec_plan_box .copy_area .copy_big small {
	font-size: calc(40/1600*100vw);
}*/
.sec_plan_box .copy_area .copy_big {
	width: 69.84%;
}
.sec_plan_box .bg_box .notes.txt_R {
	font-size: calc(17/1600*100vw);
	position: absolute;
	bottom: 10.4px;
	right: 19px;
}
@media only screen and (min-width: 1600px){
.sec_plan_box .copy_area .copy_big small {
	font-size: 40px;
}
.sec_plan_box .bg_box .notes.txt_R {
	font-size: 17px;
}
}
@media only screen and (max-width: 767px){
.sec_plan_box .copy_area {
	margin-bottom: 20px;
	flex-direction: column-reverse;
	align-items: center;
}
.sec_plan_box .copy_area .copy_big small {
	font-size: 16px;
}
.sec_plan_box .bg_box .notes.txt_R {
	font-size: 12px;
	position: relative;
	bottom: auto;
	right: auto;
}
.sec_plan_box .copy_area .copy_big {
	width: 100%;
	margin-bottom: 0;
}
.sec_plan_box .copy_area .pic {
	max-width: inherit;
	width: 32%;
}
}
@media only screen and (max-width: 400px){
.sec_plan_box .copy_area {
	align-items: center;
}
.sec_plan_box .copy_area .copy_big {
	margin-bottom: 0;
	font-size: 18px;
}
.sec_plan_box .copy_area .copy_big small {
	font-size: 14px;
}
}



/*=======================================
　sec_movie（動画が1個の場合）
=======================================*/
.sec_movie {
	margin-bottom: 90px;
}
.sec_movie .inner {
	display:-webkit-box;
	display:-webkit-flex;
	display:-ms-flexbox;
	display: flex;
	justify-content: center;
}
.sec_movie .inner .item {
	width: 59.7%;
}
.sec_movie .inner .item p {
	font-weight: 700;
	font-size: calc(28/1600*100vw);
	letter-spacing: 0.1em;
	line-height: 1.25;
	text-align: center;
	margin-bottom: 21.3px;
}
.sec_movie .inner .item iframe {
	width: 100%;
	height: 30.3vw;
	max-height: 378.05px;
	border: 3px solid #707070;
}
@media only screen and (min-width: 1600px){
.sec_movie .inner .item p {
	font-size: 28px;
}
}
@media only screen and (max-width: 767px){
.sec_movie {
	margin-bottom: 0px;
}
.sec_movie .inner .item p {
	font-size: 15px;
	margin-bottom: 10px;
}
}
@media only screen and (max-width: 640px){
.sec_movie .inner {
	display: block;
}
.sec_movie .inner .item {
	width: 100%;
}
.sec_movie .inner .item:not(:last-child) {
	margin-bottom: 30px;
}
.sec_movie .inner .item iframe {
	height: 51.4vw;
	max-height: inherit;
}
}

/*=======================================
　sec_movie（動画が2個の場合）
=======================================*/
/* .sec_movie {
	margin-bottom: 90px;
}
.sec_movie .inner {
	display:-webkit-box;
	display:-webkit-flex;
	display:-ms-flexbox;
	display: flex;
	justify-content: space-between;
	align-items: end;
	gap: 0 20px;
}
.sec_movie .inner .item {
}
.sec_movie .inner .item p {
	font-weight: 700;
	font-size: clamp(15px, calc(23/1600*100vw), 26px);
	letter-spacing: 0.1em;
	line-height: 1.25;
	text-align: center;
	margin-bottom: 21.3px;
}
.sec_movie .inner .item iframe {
	width: 100%;
	height: 23vw;
	max-height: 286.88px;
	border: 3px solid #707070;
}
@media only screen and (min-width: 1600px){
.sec_movie .inner .item p {
}
}
@media only screen and (max-width: 767px){
.sec_movie {
	margin-bottom: 0;
}
.sec_movie .inner .item p {
	font-size: 21px;
	margin-bottom: 10px;
}
}
@media only screen and (max-width: 640px){
.sec_movie .inner {
	display: block;
}
.sec_movie .inner .item {
	width: 100%;
}
.sec_movie .inner .item:not(:last-child) {
	margin-bottom: 30px;
}
.sec_movie .inner .item iframe {
	height: 51.4vw;
	max-height: inherit;
}
} */





/*============================
 sec_works
============================*/
.sec_works{
	padding-bottom:120px;
}
.sec_works .btn01{
	margin:0 auto;
}
.sec_works h3{
	font-weight: bold;
	font-size: 45px;
	text-align: center;
	padding-bottom:60px;
	line-height: 1.1;
}
.sec_works h3 span{
	color:#BA2828;
	font-weight: normal;
	font-size: 20px;
}
.sec_works .flex_area {
	gap: 3.21%;
	flex-flow: wrap;
}
.sec_works ul li {
	width: 31.16%;
	margin-bottom: 63px;
}
.sec_works ul li .img {
	margin-bottom: 20px;
	width: 100%;
	max-height: 241px;
	height: 69.25%;
	/* height: 49.2%; */
	overflow: hidden;
	background: #7A7A7A;
	text-align: center;
}
.sec_works ul li .img img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}
.sec_works ul li .icon {
	font-size: 14px;
	border: 2px solid #C9C9C9;
	border-radius: 9px;
	padding: 7px 2.4em;
	margin-bottom: 25px;
	display: inline-block;
	font-weight: 500;
}
.sec_works ul li .name {
	font-size: 20px;
	font-weight: 700;
	padding-right: 1em;
}
.sec_works ul li .date {
	font-size: 18px;
	font-family: 'Noto Sans', sans-serif;
}
.sec_works ul li a {
	position: relative;
	display: block;
}
.sec_works ul li > a::after {
    content: "";
    position: absolute;
    display: inline-block;
    top: 10px;
    -webkit-transform : translateY(-50%);
	transform : translateY(-50%);
    right: 0;
    width: 9px;
    height: 9px;
    border-top: 2px solid var(--main_color);
    border-right: 2px solid var(--main_color);
    -webkit-transform: rotate(45deg);
    transform: rotate(45deg);
}
.sec_works ul li .img a {
	width: auto;
	height: 100%;
	object-fit: cover;
}

@media only screen and (max-width: 767px){
.sec_works{
	padding-bottom:60px;
}
.sec_works h3{
	font-size: 20px;
	padding-bottom:30px;
.sec_intro .txt_area .copy {
	font-size: 21.5px;
	margin-bottom: 20px;
};
.sec_intro .txt_area .copy {
	font-size: 21.5px;
	margin-bottom: 20px;
};
}
.sec_works h3 span{
	font-size: 13px;
}
.sec_works .flex_area {
	display: flex;
	gap: 5%;
}
.sec_works ul li {
	width: 47.5%;
	margin-bottom: 31.5px;
}
.sec_works ul li .img {
	margin-bottom: 10px;
	/* height: 71%; */
	height: 30vw;
	max-height: inherit;
}
.sec_works ul li .icon {
	font-size: 12px;
	border-radius: 4.5px;
	padding: 4px 1.5em;
	margin-bottom: 12.5px;
}
.sec_works ul li .name {
	font-size: 15px;
}
.sec_works ul li .date {
	font-size: 11px;
}
.sec_works ul li a {
	position: relative;
	display: block;
}
.sec_works ul li > a::after {
    width: 6px;
    height: 6px;
    right: 2px;
}
}



/*=======================================
　sec_plan_box
=======================================*/
.sec_plan_box {
    margin-bottom: 213px;
}
@media only screen and (max-width: 767px){
.sec_plan_box {
    margin-bottom: 106.5px;
}
}



/*=======================================
　swiper
=======================================*/
.swiper {
	margin-bottom: 104.6px;
	padding-bottom: 36px;
}
.swiper-pagination-bullet {
    width: 15px;
    height: 15px;
    background: #C11920;
    margin: 0 13.5px!important;
}
.swiper-horizontal>.swiper-pagination-bullets,
.swiper-pagination-bullets.swiper-pagination-horizontal,
.swiper-pagination-custom,.swiper-pagination-fraction {
    bottom: 0;
}
@media only screen and (max-width: 767px){
.swiper {
	margin-bottom: 50px;
	padding-bottom: 25px;
}
.swiper-pagination-bullet {
    width: 7.5px;
    height: 7.5px;
    margin: 0 7px!important;
}
.swiper-horizontal>.swiper-pagination-bullets,
.swiper-pagination-bullets.swiper-pagination-horizontal,
.swiper-pagination-custom,.swiper-pagination-fraction {
    bottom: 0px;
}
}



/*=======================================
　sec_additional_parts
=======================================*/
.sec_additional_parts {
	margin-bottom: 175.9px;
}
.sec_additional_parts .copy {
	font-size: 40px;
	line-height: 1.75;
	text-align: center;
	margin-bottom: 60.8px;
}
.sec_additional_parts .txt01 {
	margin-bottom: 95px;
}
.sec_additional_parts .img {
	margin-bottom: 7.2px;
}
.sec_additional_parts .notes {
	margin-bottom: 93.8px;
	font-size: 12px;
	letter-spacing: 0.1em;
	line-height: 1.583;
}
.sec_additional_parts .btn01 {
	margin: 0 auto;
}
@media only screen and (max-width: 767px){
.sec_additional_parts {
	margin-bottom: 90px;
}
.sec_additional_parts .copy {
	font-size: 21.5px;
	margin-bottom: 30px;
}
.sec_additional_parts .txt01 {
	margin-bottom: 47.5px;
}
.sec_additional_parts .notes {
	margin-bottom: 45px;
	font-size: 11px;
}
}



/*=======================================
　top_bnr_area
=======================================*/
.top_bnr_area {
	margin-bottom: 170px;
}
@media only screen and (max-width: 767px){
	.top_bnr_area {
		margin-bottom: 85px;
	}
}

/*=======================================
　media_bnr_area
=======================================*/
.top_bnr_area {
	margin-bottom: 60px;
}
@media only screen and (max-width: 767px){
	.top_bnr_area {
		margin-bottom: 40px;
	}
}



/* 2023/10/17追加
--------------------------------------------------------- */
/*=======================================
　title_set set01
=======================================*/
@media only screen and (max-width: 768px){
	.txt_img_area .btn01 a {
		box-sizing: border-box;
	}
}



/* 2024/1/18追加
--------------------------------------------------------- */
.sec_plan_box .copy {
	font-size: 40px;
	line-height: 1.2;
	text-align: center;
}
@media only screen and (max-width: 767px){
    .sec_plan_box .copy {
	    font-size: 26px;
	    margin-bottom: 30px;
			letter-spacing: 0.02em;
    }
    .sec_plan_box .copy .txt_b {
	    font-size: 48px;
    }
}



/* 2024/1/26追加
--------------------------------------------------------- */
#cboxPrevious, #cboxNext, #cboxSlideshow, #cboxClose {
	background:url("../images/common/controls.png") no-repeat 0 0;
}
#cboxClose {
    background-position: -50px 0px;
}
.sec_movie .inner .item {
	width: calc(100%/1.5 - 10px);
}
.sec_movie .inner .item a {
	position: relative;
	display: block;
	height: 100%;
}
.sec_movie .inner .item a::after {
	content: "";
	position: absolute;
	background: url("../images/common/icon_movie.svg") no-repeat;
	background-size: cover;
	top: 50%;
	left: 50%;
	-webkit-transform : translate(-50%,-50%);
	transform : translate(-50%,-50%);
	width: 40px;
	height: 40px;
}
.sec_movie .inner .item a img {
	width: 100%;
}
@media only screen and (max-width: 767px){
	.sec_movie .inner {
		display: block;
	}
	.sec_movie .inner .item {
		width: 100%;
	}
	.sec_movie .inner .item:not(:last-child) {
		margin-bottom: 30px;
	}
}

/* 2024/4/1追加
--------------------------------------------------------- */
#movie_next {
	width: calc(100%/1.5 - 10px);
	margin: 0 auto;
	text-align: center;
	margin-bottom: 40px;
}
#movie_next p {
	font-size: calc(28/1600*100vw);
	font-weight: 700;
	margin-bottom: 21.3px;
	letter-spacing: 0.1em;
}
#movie_next img:hover {
	cursor: pointer;
}
@media only screen and (min-width: 1600px){
	#movie_next p {
	font-size: 28px;
}
}
@media only screen and (max-width: 767px){

#movie_next {
	width: 100%;
	margin-bottom: 20px;
}

#movie_next p {
	font-size: 15px;
}
}

.lity-close {
	position: absolute;
	right: -5px!important;
	top: -30px!important;
}

.swiper-slide {
	max-width: 1000px;
}

#next_jp {
	max-width: 100%;
	height: auto;
	width: 900px;
}

.heads_up {
	max-width: 1000px;
	width: 90%;
	padding: 30px 5% 40px;
	margin: 0 auto 60px;
	border: solid 1px var(--main_color);
}
.heads_up .ttl {
	max-width: 800px;
	margin-bottom: 10px;
	font-size: 40px;
	text-align: center;
	font-weight: 600;
	letter-spacing: 0.1em;
}

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

	.heads_up {
		max-width: 1000px;
		width: 90%;
		padding: 15px 5%;
		margin: 0 auto 30px;
	}
	.heads_up .ttl {
		font-size: 21.5px;
	}
}


/* 2024/9/12追加 プラマードUチャンピオンシップ2024 ダブル受賞
--------------------------------------------------------- */

.plamadou_award {
    border: 4px solid #ba9d61;
	margin: 190px auto 100px;
	padding: 0 55px 55px;
}

.plamadou_award .award_title {
    width: 80%;
    max-width: 710px;
    margin: -70px auto 30px;
    padding: 0 30px;
    background: #fff;
}

.plamadou_award .award_badge {
    width: 85%;
    max-width: 745px;
    margin: 0 auto 15px;
}

.plamadou_award .flex_area {
    justify-content: center;
    align-items: center;
    margin: 0 auto 40px;
	display: flex;
}

.plamadou_award .text_small {
    font-weight: bold;
    font-size: 20px;
    line-height: 1.6;
}

.plamadou_award .text_small .red01 {
    color: var(--main_color);
    font-size: 20px;
}

.plamadou_award .text_small {
	font-size: 12px;
	position: relative;
	padding: 0 30px;
}

.plamadou_award .text_small:before {
    content: "";
    background: url(../images/top/icon_crown.jpg) no-repeat 50% 50%;
    width: 25px;
    height: 20px;
    background-size: 25px;
    position: absolute;
    top: 56%;
    left: -2px;
    transform: translateY(-50%);
}

.plamadou_award .text_area .text_small span {
    display: inline-block;
    line-height: 1.8;
}

.plamadou_award p.text {
	font-size: 14px;
}


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

	.plamadou_award {
		border: 2px solid #ba9d61;
		margin: 80px auto 50px;
		padding: 0 15px 15px;
	}

	.plamadou_award .award_title {
		width: 100%;
		margin: -30px auto 10px;
		padding: 0 10px;
	}

	.plamadou_award .award_badge {
		width: 100%;
		margin: 0 auto 20px;
	}
	
	.plamadou_award .award_badge02 {
		width: 42%;
		margin: 0 auto 0;
	}

	.plamadou_award .flex_area {
		display: none;
		
	}

	.plamadou_award .text_small {
		font-size: 20px;
	}

	.plamadou_award .text_small .red01 {
		font-size: 15px;
		display: block;
		letter-spacing: 1px;
	}

	.plamadou_award .text_small {
		font-size: 12px;
		padding: 0 0 0 27px;
	}

	.plamadou_award .text_small:before {
		width: 20px;
		background-size: 20px;
		left: 4px;
	}
	
	.award_text {
		text-align: center;
		margin-bottom: 20px;
	}
	
	.award_text p {
		display: inline-block;
	}
	
	.plamadou_award p.text {
		font-size: 10px;
	}
	
	
}

/* 2025/8/26追加
--------------------------------------------------------- */

.news {
	text-align: center;
	margin-bottom: 100px;
}

.news .news_title {
	font-size: 44px;
    line-height: 1.75;
	font-weight: 700;
	margin-bottom: 40px;
    display: inline-block;
    border-bottom: 2px solid;
}

.news div {
	position: relative;
	display: inline-block;
}

.news div p {
    padding: 0 40px;
    font-size: 28px;
    font-weight: 600;
    margin-bottom: 10px;
}

.news p.textSmall {
    font-size: 22px;
	font-weight: 600;
	margin-bottom: 10px;
}

.news div p .textBig {
    font-size: 40px;
}

.news div p:before {
    position: absolute;
    left: 0;
    bottom: 9px;
    content: "";
    width: 2px;
    height: 60%;
    background: #333;
    border-radius: 3px;
    transform: rotate(-25deg);
}
     
.news div p:after {
    position: absolute;
    content: "";
    right: 0;
    bottom: 9px;
    width: 2px;
    height: 60%;
    background: #333;
    border-radius: 3px;
    transform: rotate(25deg);
}

.news .btn01 {
	margin-top: 50px;
}


@media only screen and (max-width: 767px){
	
	.news {
		margin: 20px auto 40px;
	}

	.news .news_title {
		font-size: 22px;
		margin-bottom: 20px;
	}

	.news div p {
		padding: 0 10px;
		font-size: 16px;
	}
	
	.news p.textSmall {
		font-size: 14px;
		margin-bottom: 10px;
	}

	.news div p .textBig {
		font-size: 22px;
	}

	.news div p:before {
		height: 2.8em;

	}

	.news div p:after {
		height: 2.8em;
	}
	
	.news .btn01 {
		margin-top: 30px;
	}	
	
	
}

@media only screen and (max-width: 320px){
	.news div p {
		letter-spacing: 0.5px;
	}

	
}

