@charset "utf-8";

:root {
	--width-pc: 980px;
	--width-sp: 375px;

	--main-theme-color:    #66A1DF;
	--sub-theme-color:     #194F74;
	--sub-theme-color-txt: #80745c;
	--main-theme-color-bg: #decdee;
}
body {
	margin:0;
	padding:0;
}
var{
	font-style: normal !important;
}
ul.breadcrumbs {
	display: flex;
	padding: 10px 2%;
	margin: 0;
	background-color: #efefef;
}
ul.breadcrumbs > li {
	display: block;
	font-size: var(--compact-font-size);
}
ul.breadcrumbs > li + li {
	margin-left: 3px;
}
ul.breadcrumbs > li + li::before {
	content: "＞";
	margin-right: 3px;
}
a:hover,
a:link,
a:visited {
	color: #000000;
}
.pc{
	display: none;
}
.sp{
	display: block;
}
#anchor01,#anchor02,#anchor03,#anchor04{
	padding-top: 80px;
	margin-top: -80px;
	clear: both;
}
/*------------------------------------*/

h1{
	margin: 0 !important;
	padding: 0 !important;
}
h2{
	margin: 0 !important;
	padding: 0 !important;
}

section.key-visual{
	width: 100%;
	clear: both;
}
section.key-visual > .main-img img {
	max-width: var(--width-pc);
}
section.situation{
	width: 100%;
}
section.situation > .main-img img {
	max-width: var(--width-pc);
}
main section.key-visual {
	width:100%;
	height:auto;
	margin-bottom: 0;
	background-repeat: no-repeat;
	background-position: top center;
}
.key-visual-inner{
	width:100%;
	height:auto;
	margin:0 auto 0;
}
.title_sp {
	display: block;
	margin-top: -40px;
}
/* キャンペーンリンク */
.campaign_wrap {
	padding: 15px 0;
	width: 100%;
	height: auto;
	margin: 0 auto;
	background-color: #FFFCD1;
	margin-bottom: 20px;
}
.cam_wrap_list {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 15px;
	font-size: 10px;
}.cam_wrap_list li {
	display: flex;
	align-items: center;
	justify-content: center;
}
.cam_wrap_list li a {
	display: block;
	width: 90%;
	text-decoration: none;
	color: #ffffff;
}
.cam_wrap_text {
	margin-top: 15px;
	display: flex;
	justify-content: center;
	align-items: center;
	font-size: 10px;
}
.cp-link-1 {
}
/* キャンペーン詳細 */
section.item{
	width: 90%;
	height: auto;
	overflow: hidden;
	margin: auto;
	display: flex;
	flex-direction: column;
}
.detail_bg {
}
.detail_bg img {
	width: 100%;
	height: auto;
}
.item-wrap {
	width: 100%;
	height: auto;
	margin-bottom: 30px;
}
.cp_detail{
	width: 100%;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
}
.cp_detail img {
	width: 100%;
	height: auto;
}
#cp-1 {
	background-repeat: no-repeat;
	background-size: 100% 100%;
	background-position: top center;
	height: auto;
	/* padding-bottom: 30px; */
}
#cp-2 {
		background-image: linear-gradient(#1a0e0b, #1a73c8);
		background-repeat: no-repeat;
		background-size: 100% 100%;
		height: auto;
		padding-top: 0;
		padding-bottom: 30px;
}

.set_item {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
}
.item-2 {
    width: 33%;
}
.set_box {
	width: 90%;
	margin: auto;
	display: flex;
	flex-wrap: wrap;
	gap: 16px;
}
.set_item a{
    text-align: center;
	width: 100%;
	margin-bottom: 15px;
}
.set_item img{
    width: 100%;
    height: auto;
    margin-bottom: 10px;
}
.set_item a:hover {
    text-decoration: none;
    opacity: 1!important;
}
.set_item span {
    display: inline-block;
    font-size: 11px;
    font-weight: 900;
    width: 100%;
    color: var(--base-color);
    background-color: var(--main-color);
    margin-bottom: 8px;
}
.set_item p {
    font-size: 10px;
    font-weight: 900;
    margin-bottom: 8px;
}
.price {
	border: #DC0010 1px solid;
	position: relative;
    border-radius: 5px;
    width: 45%;
    height: 35px;
	margin: -55px 20% 0 auto;
    font-size: 20px;
    font-weight: 900;
    color: #ffffff;
    background-color: #DC0010;
    display: flex;
    align-items: center;
    justify-content: center;
}
.price var {
    font-style: normal;
}
.set_item .price p {
    font-size: 16px!important;
    vertical-align: bottom;
    margin-bottom: -5px;
}
.set_item a:hover .price {
    background-color: #ffffff;
    color: #DC0010;
}
#cp-3 {
	background-repeat: no-repeat;
	background-size: 100% 100%;
	background-position: top center;
	height: auto;
	/* padding-bottom: 20px; */
}
/* クーポンコード */
.coupon {
    width: 90%;
    display: flex;
    flex-direction: column;
    justify-content: center;
    text-align: center;
    margin: 20px auto 20px auto;
}
.coupon button {
    margin-bottom: 5px;
}
.coupon_text p {
    font-size: 12px;
}
.coupon_text a {
    text-decoration: underline;
}
/* リンク */
.cp_link {
	display: flex;
	justify-content: center;
	text-align: center;
	margin: auto;
	z-index: 10;
	color: #ffffff;
	margin: -70px auto 20px;
	width: 250px;
}
.cp_link a {
	width: 250px;
	height: 50px;
	line-height: 50px;
	text-decoration: none;
	color: #ffffff;
	font-size: 18px;
	font-weight: bold;
	background-color: var(--sub-theme-color);
	border-radius: 10px;
}
.cp_link a:hover {
	text-decoration: none;
}
.cp1_caution {
	display: flex;
	flex-direction: column;
	text-align: left;
	margin: 10px auto 10px auto;
	width: 90%;
	font-size: 10px;
	z-index: 10;
}
/* 車種リンク */
.model {
	margin-top: -70px;
	padding-top: 70px;
}
.model_link_list {
    display: flex;
    flex-wrap: wrap;
    gap: 16px;
	margin: 0 5% 40px;
}
.model_link_item {
    width: calc(50% - 8px);
    height: auto;
}
.model_image {
	margin: 30px 0 10px;
}
.cp3_text{
	z-index: 10;
	width: 100%;
}
.cp3_box {
	display: flex;
	justify-content: center;
	align-items: center;
	margin: auto;
	width: 90%;
	margin-bottom: 15px;
}
.cp3_box img {
	width: 100%;
	height: auto;
	right: -10px;
}
.cp3_caution {
	display: flex;
	flex-direction: column;
	text-align: left;
	margin: auto;
	width: 65%;
	font-size: 10px;
	margin-bottom: 15px;
}
.cp3_caution li {
	width: 100%;
	display: flex;
	text-align: left;
}
.cp3_caution li p{
	width: 100%;
}


#pagetop {
    position: fixed;
    bottom: 50px;
    right: 3%;
    z-index: 100;
}
#pagetop a {
    background-color: var(--main-theme-color);
    display: block;
    width: 35px;
    height: 35px;
    border: var(--sub-theme-color);
    border-radius: 10%;
}
.arrow {
    position: relative;
    display: inline-block;
    width: 35px;
    height: 35px;
}
.arrow::before {
    content: '';
    width: 13px;
    height: 13px;
    border: 0;
    border-top: solid 3px var(--sub-theme-color);
    border-right: solid 3px var(--sub-theme-color);
    transform: rotate(-45deg);
    position: absolute;
    top: 55%;
    left: 50%;
    margin: 0;
    transform: translate(-50%, -50%) rotate(-45deg)
}
/*-- タブレット／PC用スタイリング --*/
/*@media screen and (min-width:768px) and (max-width:959px) {*/
@media screen and (min-width:960px) {
	.pc{
	display: block;
	}
	.sp{
	display: none;
	}
	section.key-visual{
		width: 100%;
		background-image: url("../images/55th_campaign_spr/background.png");
		background-size: 100% 100%;
	}
	section.key-visual　> .main-img img {
		max-width: var(--width-pc);
	}
	main section.key-visual {
		width:100%;
		height:auto;
	}
	.title_top {
		width: 100%;
		position: relative;
		z-index: 10;
		top: -30px;
	}
	.title_top img {
		width: 100%;
		object-fit: contain;
	}
	.cam_wrap_list {
		margin: auto;
		padding: 15px 0;
		flex-direction: row;
		gap: 20px;
		max-width: 1100px;
	}

	.cam_wrap_list li {
		display: block;
	}
	.cam_wrap_list  li a {
		max-width: calc((1100px - 40px) / 3);
		cursor: pointer;
	}
	.cam_wrap_list li img {
		width: calc((1100px - 40px) / 3);
		object-fit: contain;
	}
	.cp_link-1 {
		position: relative;
	}
	.cp_link-2 {
		position: relative;
	}
	.cp_link-3 {
		position: relative;
	}
	.cp_link {
		margin: -90px auto 20px;
		width: 350px;
	}
	.cp_link-text {
		position: absolute;
		width: 100%;
		z-index: 10;
		top:65%;
		left: 50%;
		transform: translate(-50%,-50%);
		text-align: center;
		display: flex;
		justify-content: center;
		align-items: center;
		margin: auto;
	}
	.cp_link-text p {
		font-size: 20px;
		font-weight: 900;
		color: #ffffff;
	}
	.cam_wrap_text {
		margin-top: 0;
		font-size: 16px;
	}

	/* キャンペーン詳細 */
	section.item {
		max-width: 1100px;
	}
	/* クーポンコード */
    .coupon {
        width: 780px;
        margin: 50px auto 50px auto;
    }
    .coupon button {
        font-size: 20px;
        font-weight: bold;
        margin-bottom: 10px;
    }
    .coupon-copy p {
        font-size: 20px;
        font-weight: bold;
    }

    .coupon_text p {
        font-size: 14px;
    }
	/* リンク */
	.cp_link-text {
		position: absolute;
		width: 100%;
		z-index: 10;
		top:65%;
		left: 50%;
		transform: translate(-50%,-50%);
		text-align: center;
		display: flex;
		justify-content: center;
		align-items: center;
		margin: auto;
	}
	.cp_link a {
		width: 350px;
		height: 60px;
		line-height: 60px;
		font-size: 23px;
	}
	#cp-1 {
		background-repeat: no-repeat;
		background-size: 100% 100%;
		background-position: top center;
		height: auto;
		margin-bottom: 100px;
	}
	.cp1_caution {
		width: 70%;
		font-size: 14px;
		margin: 20px 0 40px 0;
		text-align: center;
	}
	.cp1_caution li {
		display: flex;
		text-align: left;
		margin: auto;
	}
	#cp-2 {
		background-image: linear-gradient(#1a0e0b, #1a73c8);
		background-repeat: no-repeat;
		background-size: 100% 100%;
		height: auto;
		padding-top: 0;
		margin-bottom: 100px;
	}
	.model {
		width: 90%;
		margin: auto;
	}
	.model_link_item {
		width: calc(33% - 8px);
		height: auto;
	}
	.model_image {
		margin: 30px 0 20px;
	}
	.set_item{
		width: calc(50% - 8px);
	}
	.price {
		width: 45%;
		height: 50px;
		margin: -75px 20% 0 auto;
		font-size: 25px;
	}
	#cp-3 {
		background-repeat: no-repeat;
		background-size: 100% 100%;
		background-position: top center;
		height: auto;
		position: relative;
	}
	#pagetop a {
		width: 50px;
		height: 50px;
	}
	.arrow {
		width: 50px;
		height: 50px;
	}
	.arrow::before {
		content: '';
		width: 20px;
		height: 20px;
		border: 0;
		border-top: solid 3px var(--sub-theme-color);
		border-right: solid 3px var(--sub-theme-color);
		transform: rotate(-45deg);
		position: absolute;
		top: 60%;
		left: 50%;
		margin: 0;
		transform: translate(-50%, -50%) rotate(-45deg)
	}
}
@media screen and (max-width:400px) {
}
@media screen and (min-width:960px) {
}
@media screen and (min-width:1100px) {
}
@media screen and (max-width:1320px) {
}
@media screen and (min-width:1500px) {
}