@charset "utf-8";
h2 {
  letter-spacing: 0.08em;
}
/* ボタン */
#main_contents a,
#main_contents .btn {
	transition-property: all;
	transition: 0.2s linear;
}
#main_contents .card a,
#main_contents .ranking-card a {
  display: block;
}
#main_contents a:hover,
#main_contents .btn:hover {
  text-decoration: none;
}
#mv_left {
  padding-left: 0;
  width: 100%;
}
#mv_right {
  padding-left: 15px;
  padding-right: 15px;
  width: 100%;
}
#mv_right .card-header {
  height: auto;
  padding-top: 0;
  padding-bottom: 0;
}
#mv_right .card-header p {
  line-height: 48px;
}
#mv_right .card-element p {
  font-size: 12px;
}
#mv_right .card-text {
  font-size: 9px;
}
/**/
.container {
  width: 100%;
  margin-left: 0;
  margin-right: 0;
  padding-left: 15px !important;
  padding-right: 15px !important;
  max-width: 100%;
}
.container .lead {
  font-size: 14px !important;
}
.recall-area .text-center, .recall-area .arr-right {
  margin-top: 0;
  margin-bottom: 0;
}
.container .recall-area p {
  font-size: 12px;
}
.container .icon-ranking {
  width: 23px;
  height: 23px;
}
#ranking .card-text span {
  font-size: 14px;
}
#lineup .row {
  margin-left: 0 !important;
  margin-right: -9px !important;
}
#lineup .item {
  padding-left: 0;
  padding-right: 9px;
  margin-bottom: 0;
}
#lineup .card-text {
  line-height: 12px;
  padding-left: 0;
  padding-right: 0;
}
#lineup .card-text span {
  font-size: 12px;
  line-height: 1.2;
}
#lineup .card-price {
  font-size: 12px;
  padding-top: 0;
  padding-bottom: 10px;
}
#lineup .bd-none {
  border-top: 1px solid #d5d5d5 !important;
}
#lineup .card-element p, #lineup .card-element2 p, #lineup .card-element3 p {
  font-size: 12px !important;
  color: #707070;
  line-height: 1em !important;
  padding: 6px !important;
}
#lineup .btn {
  font-size: 15px !important;
}
#recommend_useful .row {
  margin-left: 0 !important;
}
#recommend_useful .heightCtr {
  padding: 0 !important;
}
#recommend_useful .col-sm-12, #recommend_useful .col-md-4, #recommend_useful .mt-4,
#special_area .col-sm-12, #recommend_useful .col-md-4, #recommend_useful .mt-4 {
  padding: 0 !important;
}
#recommend_useful .card-header-news, #recommend_useful .card-header-tvcm, #recommend_useful .card-header-info, #special_area .card-header-info {
  padding: 8px 10px;
}
#recommend_useful .card-header-news p, #recommend_useful .card-header-tvcm p, #recommend_useful .card-header-info p, #special_area .card-header-info p {
  font-size: 14px;
  line-height: 1.2;
}
#recommend_useful .card-body-content p, #recommend_useful .card-body-content2 p, #recommend_useful .card-body-content3 p {
  font-size: 12px;
  line-height: 1.5;
  margin-top: 3px;
  margin-bottom: 3px;
}
#recommend_useful .content {
  padding: 0 !important;
}
#recommend_useful .btn,
#whatsnew .btn {
  font-size: 15px !important;
  border-radius: 0;
}
#whatsnewCtt li a {
  font-size: 12px;
  display: block;
  text-indent: -7em;
  padding-left: 7em;
}
@media screen and (max-width: 767px) {
  #whatsnewCtt li a {
    text-indent: 0;
    padding-left: 0;
  }
}

#mailmagazine h3, #related_link h3 {
  font-size: 16px;
  color: #000000;
  /* margin-bottom: 0; */
}
#mailmagazine p {
  font-size: 12px;
  color: #707070;
}
#mailmagazine .btn {
  font-size: 15px;
}
#related_link {
  padding: 40px 0;
}
#related_link .row {
  margin-right: -6px !important;
}
#related_link .row > div {
  margin-top: 6px;
  padding-right: 9px;
  padding-left: 0;
}
.l-footer-contents {
  margin-top: 0 !important;
}
/*


*/
@media screen and (min-width: 751px) {
  #ranking .card-text {
    font-size: 16px;
    padding: 10px 0 0;
  }
  .container #lineup .item {
    padding-right: 15px !important;
  }
  #lineup .row {
    margin-right: -15px !important;
  }
  #lineup .card-text {
    line-height: 0.6;
  }
#recommend_useful .row {
  margin-right: 0 !important;
}
  #recommend_useful .item,
  #special_area .item {
    padding-right: 15px !important;
  }
  #related_link .row {
    margin-right: -6px !important;
    margin-left: 0;
  }
  #mailmagazine p {
    text-align: center;
  }
  #gblFooter {
    margin-top: 0;
  }
}
/*


*/
@media screen and (min-width: 961px) {
  #mv {
    width: 100%;
    /* padding: 10px 10px 0; */
  }
  #mv_left {
    float: left;
    width: 72%;
    padding-right: 10px;
  }
  #mv_right {
    float: right;
    width: 28%;
    padding: 0;
  }
  #mv .card-text {
    font-size: 14px;
  }
  #mv .card-element p {
    font-size: 18px;
    padding: 0;
    line-height: 52px;
  }
  .container .lead {
    font-size: 20px !important;
  }
  .container .recall-area p {
    font-size: clamp(0.875rem, 0.83rem + 0.23vw, 1rem);
  }
  .container h3.mt-md-7 {
    margin-top: 50px !important;
    margin-bottom: 20px !important;
  }
  #ranking .card-text span {
    font-size: 16px;
  }
  #lineup .card-text {
    line-height: 19px;
  }
  #lineup .card-text span {
    font-size: 18px;
  }
  #lineup .card-price {
    font-size: 16px !important;
    padding-bottom: 10px !important;
  }
  #lineup .card-element p, #lineup .card-element2 p, #lineup .card-element3 p {
    font-size: 16px !important;
  }
  #lineup .bd-none {
    /* border: none !important; */
  }
  #lineup .btn {
    font-size: 18px !important;
  }
  #recommend_useful .row {
    margin-right: 0 !important;
  }
  #recommend_useful .card-header-news p, #recommend_useful .card-header-tvcm p, #recommend_useful .card-header-info p {
    font-size: 16px;
  }
  #recommend_useful .card-body-content p, #recommend_useful .card-body-content2 p, #recommend_useful .card-body-content3 p,
  #special_area .card-body-content p, #special_area .card-body-content2 p, #special_area .card-body-content3 p {
    font-size: 16px;
    font-weight: 700;
    line-height: 1.5;
  }
  #recommend_useful .btn,
  #special_area .btn,
  #whatsnew .btn {
    font-size: clamp(0.875rem, 0.784rem + 0.45vw, 1.125rem) !important;
  }
  #whatsnewCtt li a {
    font-size: clamp(0.75rem, 0.705rem + 0.23vw, 0.875rem);
  }
  #mailmagazine h3, #related_link h3 {
    font-size: 23px;
    color: #4d4d4d;
  }
  #mailmagazine p {
    font-size: 16px;
  }
}
/*


*/
@media screen and (min-width: 1383px) {
  .container {
    width: 1233px;
    margin-left: auto;
    margin-right: auto;
    padding-left: 0 !important;
    padding-right: 0 !important;
  }
}
/*


*/
@media screen and (min-width: 1500px) {
  #mv {
    width: 100%;
    margin: 0 auto;
    max-width: 3000px;
  }
  #mv_left {
    width: 985px;
    padding: 0;
  }
  #mv_right {
    width: 360px;
  }
  #mv .card-text {
    padding: 15px 10px;
    line-height: 20px;
  }
}

.heightCtr .card a{
	min-height: 0%;
	display: block;
}

/*----------------------------------------*/
/*----------------------------------------*/
/*

/* 202303 リニューアル追記 */
.btn-area {
  margin: 22px 0 40px;
}
@media screen and (min-width: 768px) {
  .btn-area {
    margin: 20px 0 30px;
  }
}

/*----------------------------------------
	btnList
----------------------------------------*/
.btnList-area {
	display: block;
	text-decoration: none;
	/* transition: color .3s; */
}
.btnList_item {
  box-shadow: 0px 0px 5px 1px rgb(6 1 2 / 20%);
}
.btnList_item:last-child {
  border-right: none;
}
.btn_thumb {
	overflow: hidden;
	margin-right: 20px;
}
.btn_thumb p {
  line-height: 0;
  margin-top: 0;
  margin-bottom: 0;
  display: inline;
}
.btn_thumb img {
	max-width: 70%;
	width: 100%;
  height: auto;
  vertical-align: middle;
}
.btn_txt {
	padding-right: 14px;
  text-align: center;
  color: #666666;
  font-weight: 500;
  font-size: 18px;
}
.btnList .mediaIndex {
  position: relative;
  display: flex;
	flex-direction: column;
	min-width: 0;
	word-wrap: break-word;
	background-color: #fff;
	background-clip: border-box;
  border: none;
  border-radius: 0;
  padding-top: 16px;
  padding-bottom: 16px;
}

@media screen and (max-width: 767px) {
  .btn_txt span {
    opacity: 1;
  }
  .btnList_item {
    border-right: none;
    border-top: 1px solid #e5e5e5;
  }
  .btnList_item:last-child {
    border-bottom: 1px solid #e5e5e5;
  }
  .btnList_item .arrow-right:after {
    opacity: 0;
  }
}

/*hover*/
.btn:hover {
}
.btn:hover .btn_thumb img {
}

/*----------------------------------------
	btnList
----------------------------------------*/
.btnList {
	display: grid; /*girdレイアウトにする*/
	gap: 15px; /*アイテム間余白を15pxに設定*/
	grid-template-columns: repeat(1,1fr);
}

@media screen and (min-width: 768px) {
  .btnList {
    grid-template-columns: 1fr 1fr 1fr 1fr 1fr;
  }
  /*補足
最小値の297pxは、コンテナ幅1233pxの時4カラムで表示したいというデザイン的な意図から算出しています。

コンテナ幅：1233px
カラム数：4
gap：15px　×　3個 = 45px

各カラムの幅 = (1233px - 45px) / 4  = 297px　※これが実質最小値
*/

  .btn_thumb img {
    width: 20%;
    vertical-align: baseline;
    margin-top: 0;
    margin-left: 0;
  }
  .btn_thumb img.icon_size {
    width: 28%;
    margin-top: 8px;
  }
  .btn_thumb p {
    display: block;
    text-align: center;
  }
  .btn_txt {
    font-size: clamp(0.688rem, 0.574rem + 0.57vw, 1rem);
  }
}

.btn_thumb {
	position: relative;
	/* transition: .3s; */
	width: 100%;
	margin-right: 0;
	flex-shrink: 0;
}
.btnList_body {
	flex-grow: 1;
	/* background: #e7e7e7; */
}
.btn_txt {
	margin-top: 1em;
  margin-bottom: 4px;
  letter-spacing: -0.04em;
}
.btn_txt.icon5_2 {
	margin-top: 0.7em;
}



/*----------------------------------------
	mediaIndex
----------------------------------------*/
@media screen and (max-width: 767px),print {
.btnList .mediaIndex {
	display: flex;
	align-items: center;
	padding: 16px 0;
	border-bottom: 1px solid #e7e7e7;
	color: inherit;
	text-decoration: none;
	/* transition: color .3s; */
  position: static;
  flex-direction: row;
}
.btnList .mediaIndex.icon5 {
  padding: 18px 0;
}
.btn_thumb {
	position: relative;
	/* transition: .3s; */
	width: 12%;
	margin-right: 16px;
  margin-left: 15px;
	flex-shrink: 0;
}
.btn_txt {
	font-size: clamp(1rem, 0.955rem + 0.23vw, 1.125rem);
  font-weight: 500;
  color: #666666;
  text-align: left;
  margin: 0;
  letter-spacing: 0;
}
.btn_txt.icon5_2 {
	margin-top: 0;
}
}

/*矢印付き*/
.btn-arrow {
	position: relative;
	display: inline-block;
}
.btn-arrow::after {
	position: absolute;
	right: 20px;
	top: 0;
	bottom: 0;
	margin: auto;
	content:"";
	display: block;
	width: 0.7em;
	height: 0.7em;
	border-top: 2px solid;
	border-right: 2px solid;
	color: #666666;
	transform: rotate(45deg);
}

@media screen and (min-width: 768px) {
  .btn-arrow::after {
    color: #ffffff;
  }
}


/*----------------------------------------
	arrow
----------------------------------------*/
.arrow_r {
  position: relative;
  display: inline-block;
  text-decoration: none;
}
.arrow_r:after {
  content: '';
  width: 10px;
  height: 10px;
  border: 0;
  border-top: solid 2px #002a80;
  border-right: solid 2px #002a80;
  position: absolute;
  top: 50%;
  /* right: 0; */
  margin-top: -4px;
  margin-left: 10px;
  transform: rotate(45deg);
}

/*----------------------------------------
	lineupTab
----------------------------------------*/
.tab-wrap {
	background: White;
  border-top: none;
	/* box-shadow: 0 0 5px rgba(0,0,0,.1); */
	display: flex;
	flex-wrap: wrap;
	overflow: hidden;
}

.tab-label {
	color: #555555;
  background: #f2f2f2;
  margin-bottom: 0;
	cursor: pointer;
	flex: 1;
  font-size: clamp(0.75rem, 0.614rem + 0.68vw, 1.125rem);
	font-weight: bold;
	order: -1;
	padding: 5px 8px;
	position: relative;
	text-align: center;
	transition: cubic-bezier(0.4, 0, 0.2, 1) .2s;
	user-select: none;
	white-space: nowrap;
	-webkit-tap-highlight-color: transparent;
  border-top: 1px solid #d9d9d9;
  border-left: 1px solid #d9d9d9;
  border-right: 1px solid #d9d9d9;
  /* border-bottom: 1px solid #002b80; */
  display: flex; /* セニアカーをタブに追加して天地左右センターにするために追記 */
  justify-content: center; /* セニアカーをタブに追加して天地左右センターにするために追記 */
  align-items: center; /* セニアカーをタブに追加して天地左右センターにするために追記 */
}
@media screen and (min-width: 768px) {
  .tab-label {
    margin-right: 20px;
    padding: 10px 8px;
  }
  .tab-label.last {
    margin-right: 0; 
  }
}

.tab-label:hover {
	/* background: rgba(0, 191, 255,.1); */
}

.tab-switch:checked + .tab-label {
	color: #002b80;
  background: #ffffff;
  border-bottom: none;
  border-left: 1px solid #002b80;
  border-right: 1px solid #002b80;
  border-top: 1px solid #002b80;
  z-index: 9;
  bottom: -1px;
}

.tab-label::after {
	background: #002b80;
	top: -1px;
	content: '';
	display: block;
	height: 4px;
	left: 0;
	opacity: 0;
	pointer-events: none;
	position: absolute;
	transform: translateX(100%);
	transition: cubic-bezier(0.4, 0, 0.2, 1) .2s 80ms;
	width: 100%;
	z-index: 1;
}

.tab-switch:checked ~ .tab-label::after {
	transform: translateX(-100%);
}

.tab-switch:checked + .tab-label::after {
	opacity: 1;
	transform: translateX(0);
  border-top: none;
}

.tab-content {
	height:0;
	opacity:0;
	pointer-events:none;
	transform: translateX(-30%);
	transition: transform .3s 80ms, opacity .3s 80ms;
	width: 100%;
  border-left: 1px solid #002b80;
  border-right: 1px solid #002b80;
  border-bottom: 1px solid #002b80;
  border-top: 1px solid #002b80;
  position: relative;
  /* top: -1px; */
}

.tab-content::before {
  border-top: 1px solid #002b80;
}

.tab-switch:checked ~ .tab-content {
	transform: translateX(30%);
}

.tab-switch:checked + .tab-label + .tab-content {
	height: auto;
	opacity: 1;
	/* order: 1; */
	pointer-events:auto;
	transform: translateX(0);
  padding: 10px 0 20px;
}

.tab-switch:checked + .tab-label + .tab-content.tab01 {
  /* top: -1px; */
}

.tab-switch:checked + .tab-label + .tab-content.tab02 {
  top: -2px;
}

.tab-switch:checked + .tab-label + .tab-content.tab03 {
  top: -4px;
}

.tab-switch:checked + .tab-label + .tab-content.tab04 {
  top: -6px;
}

.tab-switch:checked + .tab-label + .tab-content.tab05 {
  top: -8px;
}

.tab-wrap::after {
	content: '';
	/* height: 20px; */
	order: -1;
	width: 100%;
}

.tab-switch {
	display: none;
}
.carLineup {
	display: block;
	text-decoration: none;
	transition: color .3s;
}
.carLineuplist_item {
  /* margin: 10px 0; */
}
.carLineup_thumb {
	overflow: hidden;
  padding-bottom: 5px;
}
.carLineup_thumb img {
	max-width: none;
	width: 100%;
  height: auto;
	transition: transform .3s;
}
.carLineup_txt {
	margin: 0;
  text-align: center;
  font-weight: 700;
  font-size: clamp(0.875rem, 0.83rem + 0.23vw, 1rem);
  line-height: 1.3;
}
.carLineup_txt span {
  font-weight: 400;
  font-size: clamp(0.75rem, 0.705rem + 0.23vw, 0.875rem);
}
/*hover*/
.carLineup:hover {
}
.carLineup:hover .card__thumb img {
}

/*----------------------------------------
	CardList
----------------------------------------*/
.carLineuplist {
	display: grid;
	gap: 15px; /*アイテム間余白を15pxに設定*/
	grid-template-columns: repeat(2,1fr);
}

@media screen and (min-width: 768px) {
  .carLineuplist {
    grid-template-columns: repeat(auto-fill,minmax(192px,1fr));
  }
}
/*補足
最小値の192pxは、コンテナ幅1231pxの時6カラムで表示したいというデザイン的な意図から算出しています。

コンテナ幅：1231px（1233pxから左右border各1px）
カラム数：6
gap：15px　×　5個 = 75px

各カラムの幅 = (1231px - 75px) / 6  = 192px　※これが実質最小値
*/

#special_area,
#useful_information {
  margin: 45px 0 60px;
}

/*----------------------------------------
	cardList01　PC 4分割 / SP 1分割
----------------------------------------*/
.cardList01 {
	display: grid;
	gap: 15px; /*アイテム間余白を15pxに設定*/
	grid-template-columns: repeat(1,1fr);
}

@media screen and (min-width: 751px) {
  .cardList01 {
    grid-template-columns: repeat(4,1fr);
  }
}

.cardList01_item {
  border: 1px solid #e6e6e6;
  background-color: #ffffff;
}
.cardList01_thumb {
	overflow: hidden;
}
.cardList01_thumb img {
	max-width: none;
	width: 100%;
  height: auto;
	transition: transform .3s;
}
.cardList01_item p,
.slide_title,
.slide-content p {
  margin: 9px 11px 11px;
  font-size: clamp(1rem, 1rem + 0vw, 1rem);
  font-weight: 500;
  text-align: left;
}
.cardList01_txt {
	margin: 0;
  text-align: left;
  font-weight: 500;
  font-size: clamp(0.875rem, 0.83rem + 0.23vw, 1rem);
  line-height: 1.3;
}
.cardList01_txt.txt_400 {
  font-size: clamp(0.75rem, 0.705rem + 0.23vw, 0.875rem);
  font-weight: 400;
  margin: 0 11px 11px;
}

/*----------------------------------------
	cardList02 PC 6分割 / SP 2分割
----------------------------------------*/
.cardList02_thumb {
	overflow: hidden;
}
.cardList02_thumb img {
	max-width: none;
	width: 100%;
	transition: transform .3s;
}

.cardList02 {
	display: grid; /*girdレイアウトにする*/
	gap: 15px; /*アイテム間余白を15pxに設定*/
  grid-template-columns: repeat(2,1fr);
}
@media screen and (min-width: 751px) {
  .cardList02 {
    grid-template-columns: repeat(auto-fill,minmax(193px,1fr));
  }
}

/*----------------------------------------
	cardList03　PC 3分割 / SP 1分割
----------------------------------------*/
.cardList03_item {
  border: 1px solid #d9d9d9;
  background: #ffffff;
}

.cardList03_thumb {
	overflow: hidden;
}
.cardList03_thumb img {
	max-width: none;
	width: 100%;
	transition: transform .3s;
}
.cardList03_txt {
	margin: 0px 9px 18px;
  font-size: clamp(1rem, 1rem + 0vw, 1rem);
  font-weight: 500;
}
.cardList03 {
	display: grid; /*girdレイアウトにする*/
	gap: 16px; /*アイテム間余白を16pxに設定*/
  grid-template-columns: repeat(1,1fr);
}
@media screen and (min-width: 751px) {
  .cardList03 {
    grid-template-columns: repeat(3,1fr);
  }
}

/*----------------------------------------
	cardPickup
----------------------------------------*/
.cardPickup {
	position: relative;
	display: -ms-flexbox;
	display: flex;
	-ms-flex-direction: column;
	flex-direction: column;
	min-width: 0;
	word-wrap: break-word;
	background-color: #fff;
	background-clip: border-box;
	border: 1px solid #C0C0C0;
}
.cardPickupIcon {
  font-size: clamp(0.75rem, 0.705rem + 0.23vw, 0.875rem);
  font-weight: 700;
  display: inline-block;
  padding: 0 26px;
  text-align: center;
  color: #ffffff;
  margin: 6px 9px 9px;
}
.cardPickupIcon.icon_tvcm {
  background-color: #0068b6;
}
.cardPickupIcon.icon_campaign {
  background-color: #329f5b;
}

@media screen and (min-width: 751px) {
  .cardPickupIcon {
    padding: 0 26px;
  }
}

#recommend_useful .card-body-content3 p.cardPickup-text,
#special_area .card-body-content3 p.cardPickup-text {
  font-size: clamp(0.75rem, 0.705rem + 0.23vw, 0.875rem);
  font-weight: 400;
  line-height: 1.5;
}


.swiper-slide figure {
  margin: 0;
}

.h2-title {
  text-align: center;
}

h2.h2-top {
  position: relative;
  display: inline-block;
  margin-bottom: 2.6041rem !important;
}

/*以下で線を表示*/
h2.h2-top:before {
  content: '';
  position: absolute;
  left: 50%;
  bottom: -20px;/*線の上下位置*/
  display: inline-block;
  width: 100%;/*線の長さ*/
  height: 3px;/*線の太さ*/
  -webkit-transform: translateX(-50%);
  transform: translateX(-50%);/*位置調整*/
  border-bottom: 3px solid #002c80;
  border-image: linear-gradient(to right, #002c80 0%, #2fcdcf 100%) 1;
  text-decoration: none;
}

/*----------------------------------------
	search btn_selection
----------------------------------------*/
.btns {
  display: flex; /*flexbox化*/
  justify-content: center; /*主軸方向に中央揃え*/
}
.btns_item {
  width: 80%;
  max-width: 450px;
}
.btn_cmcampaign {
	display: block;
	padding: 12px;
	text-align: center;
	text-decoration: none;
  color: #ffffff;
  font-weight: 700;
  font-size: 18px;
}
.btn_tvcm {
  background: #0068b6;
}
.btn_campaign {
  background: #329f5b;
}
.btn_inactive {
  background: #999999;
}
.btns_item li {
  cursor: pointer;
}
.none {
  display: none;
}
div#swiper-card01-car .card01 .swiper-wrapper a {
  height: auto;
}

#cmcampaign_tvcm {
  display: none;
}
#cmcampaign_campaign {
  display: none;
}
.active {
  transition: 0.5s;
}

@media only screen and (max-width: 428px) {
  .btns_item {
    width: 100%;
  }
}

/*----------------------------------------
	modal-renewal
----------------------------------------*/
.modal_open{
  display: inline-block;
  cursor: pointer;
}

.modal_box {
  position: fixed;
  z-index: 7777;
  display: none;
  width: 80%;
  max-width: 940px;
  margin: 0;
  padding: 60px 2vw 80px;
  border: 2px solid #aaa;
  text-align: center;
  background: #fff;
  box-sizing: border-box;
}

.modal_close {
  position: absolute;
  top: 0;
  right: 0;
  display: block;
  width: 62px;
  font-size: 46px;
  color: #000;
  line-height: 62px;
  text-align: center;
  background: #e6e6e6;
  cursor: pointer;
}

.modal_close i {
  line-height: 62px;
  vertical-align: bottom;
}

.modal_bg {
  position: fixed;
  top: 0;
  left: 0;
  z-index: 6666;
  display: none;
  width: 100%;
  height: 120%;
  background-color: rgba(0,0,0,0.7);
}

@media screen and (max-width: 769px) {

/*  ウィンドウサイズ769px以下の時のスタイル  */
.modal_box {
    padding: 50px 2vw 40px;
}

.modal_close {
    width: 40px;
    line-height: 40px;
    font-size: 30px;
}

.modal_close i {
    line-height: 44px;
}
}

/*----------------------------------------
	swiper
----------------------------------------*/
.l-inner {
  position: relative;
  -webkit-box-sizing: content-box;
          box-sizing: content-box;
  max-width: 1233px;
  margin: 0 auto;
}

.l-section {
}
.l-section .l-inner {
}

.slide-media,
.thumb-media {
}
.slide-media img,
.thumb-media img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}


.swiper-button-prev, .swiper-button-next {
  display: grid;
  place-content: center;
  width: 6.4rem;
  height: 6.4rem;
  cursor: pointer;
  -webkit-transition: var(--transition);
  transition: var(--transition);
}
.swiper-button-prev::before, .swiper-button-next::before {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  content: "";
  border-radius: 50%;
  -webkit-box-shadow: var(--box-shadow);
          box-shadow: var(--box-shadow);
}
.swiper-button-prev::after, .swiper-button-next::after {
  width: 1.2rem;
  height: 1.2rem;
  content: "";
  border: solid var(--color-gray);
  border-width: 3px 3px 0 0;
}
.swiper-button-prev::after {
  margin-left: 0.4rem;
  -webkit-transform: rotate(-135deg);
          transform: rotate(-135deg);
}
.swiper-button-next::after {
  margin-right: 0.4rem;
  -webkit-transform: rotate(45deg);
          transform: rotate(45deg);
}
.swiper-button-disabled {
  pointer-events: none;
  opacity: 0;
}

.card01 .swiper-area,
.card02 .swiper-area {
  position: relative;
}
.card01 .swiper-button-prev, .card01 .swiper-button-next,
.card02 .swiper-button-prev, .card02 .swiper-button-next {
  position: absolute;
  z-index: 1;
  top: 10px;
  bottom: 0;
  margin: auto;
}
.card01 .swiper-button-prev,
.card02 .swiper-button-prev {
  /* right: calc(100% - 45rem); */
}
.card01 .swiper-button-next,
.card02 .swiper-button-next {
  /* left: calc(100% - 45rem); */
}
.card01 .slide-media,
.card02 .slide-media {
  padding-top: 62.5%;
  border-radius: 4px;
}
.card01 .slide-media img,
.card02 .slide-media img {
  /* height: calc(100% + 16px); */
  /* -webkit-transform: translateY(-16px); */
          /* transform: translateY(-16px); */
}
.card01 .slide-content,
.card02 .slide-content {
  padding: 3.2rem 0;
}
.card01 .slide-date,
.card02 .slide-date {
  font-size: 1.2rem;
  line-height: 1;
  display: block;
  color: var(--color-theme);
}
.card01 .slide-title,
.card02 .slide-title {
  line-height: 1.6;
  display: -webkit-box;
  overflow: hidden;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  height: 3.2em;
  margin-top: 1.6rem;
}
.card01 .swiper-button-area,
.card02 .swiper-button-area,
.card04 .swiper-button-area {
  position: relative;
}
.card01 .swiper,
.card02 .swiper {
  overflow: hidden;
}


@media only screen and (max-width: 1024px) {
  .l-inner {
  }
  .pc {
    display: none !important;
  }
  .card01 .swiper-button-prev::before, .card01 .swiper-button-next::before,
  .card02 .swiper-button-prev::before, .card02 .swiper-button-next::before {
  }
  .card01 .swiper-button-prev::after, .card01 .swiper-button-next::after,
  .card02 .swiper-button-prev::after, .card02 .swiper-button-next::after {
    border-color: #fff;
  }
  .card01 .swiper-button-prev,
  .card02 .swiper-button-prev {
    /* right: calc(100% - 20rem); */
  }
  .card01 .swiper-button-next,
  .card02 .swiper-button-next {
    /* left: calc(100% - 20rem); */
  }
}

@media only screen and (max-width: 599px) {
  .pc-tab {
    display: none !important;
  }
}

@media only screen and (min-width: 1025px) {
  .tab-sp {
    display: none !important;
  }
  .swiper-button-prev::before, .swiper-button-next::before {
    -webkit-transition: var(--transition);
    transition: var(--transition);
  }
  .swiper-button-prev:hover::before, .swiper-button-next:hover::before {
    -webkit-transform: scale(1.2);
            transform: scale(1.2);
  }
  .card01 .swiper,
  .card02 .swiper {
    overflow: hidden;
  }
  .card01 .slide,
  .card02 .slide {
    /* -webkit-transition: var(--transition); */
    /* transition: var(--transition); */
  }
  .card01 .slide img,
  .card02 .slide img {
    /* -webkit-transition: var(--transition); */
    /* transition: var(--transition); */
  }
}

@media only screen and (min-width: 600px) {
  .sp {
    display: none !important;
  }
}

.swiper-slide {
  background: #ffffff;
}
.swiper-pagination-area {
  border-top: 1px solid #e6e6e6;
  border-bottom: 1px solid #e6e6e6;
  padding-top: 12px;
  padding-bottom: 12px;
  background-color: #f2f2f2;
  position: relative;
}
.swiper-container .swiper-pagination-clickable .swiper-pagination-bullet {
  margin-top: 0;
  margin-bottom: 0;
}

/*----------------------------------------
	swiper 矢印を画像に
----------------------------------------*/
/* 幅・高さを指定 */
.swiper-button-prev,
.swiper-button-next {
  height: 30px;
  width: 30px;
}

/*----------------------------------------
	swiper 767以下でswiper使用
----------------------------------------*/
.l-inner {
  position: relative;
  -webkit-box-sizing: content-box;
          box-sizing: content-box;
  max-width: 1233px;
  margin: 0 auto;
}

.l-section {
}
.l-section .l-inner {
}

.slide-media,
.thumb-media {
}
.slide-media img,
.thumb-media img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

.card04 .swiper {
  overflow: hidden;
}
.card04 .swiper-button-prev, .card04 .swiper-button-next {
  position: absolute;
  z-index: 1;
  top: 10px;
  bottom: 0;
  margin: auto;
}
.card04 .swiper-button-prev::before, .card04 .swiper-button-next::before {
}
.card04 .swiper-button-prev::after, .card04 .swiper-button-next::after {
}
.card04 .swiper-button-prev {
  right: calc(100% - 1.6rem);
}
.card04 .swiper-button-next {
  left: calc(100% - 1.6rem);
}
.card04 .swiper-a:not(.swiper-initialized) {
  padding: 0;
}
.card04 .swiper-a:not(.swiper-initialized) .swiper-button-prev,
.card04 .swiper-a:not(.swiper-initialized) .swiper-button-next {
  display: none;
}
.card04 .swiper-a:not(.swiper-initialized) .swiper-wrapper {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
}
.card04 .swiper-b:not(.swiper-initialized) {
  padding: 0;
}
.card04 .swiper-b:not(.swiper-initialized) .swiper-button-prev,
.card04 .swiper-b:not(.swiper-initialized) .swiper-button-next {
  display: none;
}
.card04 .swiper-b:not(.swiper-initialized) .swiper-wrapper {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 16px;
}
.card04 .slide {
  overflow: hidden;
}
.card04 .slide-media {
  padding-top: 62.5%;
}

.card04 .slide-title {
  line-height: 1.6;
  display: -webkit-box;
  overflow: hidden;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  height: 3.2em;
  margin-top: 1.6rem;
}

.card04 .swiper-slide,
.card02 .swiper-slide {
  border: 1px solid #d9d9d9;
}


@media only screen and (max-width: 767px) {
  .l-inner {
  }
  .pc {
    display: none !important;
  }
  .card04 .swiper {
  }
  .card04 .swiper-button-prev {
    left: 0 !important;
  }
  .card04 .swiper-button-next {
    right: 0 !important;
  }
}

@media only screen and (max-width: 599px) {
  .pc-tab {
    display: none !important;
  }
  .card04 .swiper-b:not(.swiper-initialized) .swiper-wrapper {
    grid-template-columns: repeat(1, 1fr);
  }
}

@media only screen and (min-width: 1025px) {
  .tab-sp {
    display: none !important;
  }
  .swiper-button-prev::before, .swiper-button-next::before {
    -webkit-transition: var(--transition);
    transition: var(--transition);
  }
  .swiper-button-prev:hover::before, .swiper-button-next:hover::before {
    -webkit-transform: scale(1.2);
            transform: scale(1.2);
  }
  .card04 .slide {
    -webkit-transition: var(--transition);
    transition: var(--transition);
  }
  .card04 .slide img {
  }
  .card04 .slide:hover {
  }
  .card04 .slide:hover img {
  }
}

@media only screen and (min-width: 768px) {
  .sp {
    display: none !important;
  }
  .card04 .swiper-button-area {
    display: none !important;
  }
}

@media only screen and (max-width: 1024px) and (min-width: 600px) {
  .card04 .swiper-b:not(.swiper-initialized) .swiper-wrapper {
    grid-template-columns: repeat(2, 1fr);
    gap: 16px;
  }
}


/*----------------------------------------
	slick
----------------------------------------*/
.data-slick .slick-slide{
  margin: 0 8px;
}

.slide-arrow {
  position: absolute;
  cursor: pointer;
  z-index:2 !important;
}

.slide-arrow.prev-arrow {
  top: 102%;
  left: calc(50% - 165px);
  right: auto;
}

.slide-arrow.next-arrow {
  top: 102%;
  right: calc(50% - 165px);
  left: auto;
}

@media only screen and (max-width: 767px) {
  .slide-arrow.prev-arrow {
    left: 0;
  }
  .slide-arrow.next-arrow {
    right: 0;
  }
}

.slick-dots li button:before{
  top: 0px !important;
  left: -10px !important;
  content: ""  !important;
  background-color: #cccccc;
  border-radius: 50%;
  width: 12px !important;
  height: 12px !important;
}

.slick-dots li.slick-active {
  color: #002b80;
}

.slick-dots li {
  color: #cccccc;
}

ul.filter {
  display: flex;
  justify-content: center;
}

ul.filter li {
  padding: 6px;
  text-decoration: none;
  color: #ffffff;
  font-weight: 700;
  font-size: clamp(0.813rem, 0.699rem + 0.57vw, 1.125rem);
  text-align: center;
  cursor: pointer;
  display: block;
  width: 100%;
  margin: 0 8px 20px;
}

.no-point {
  pointer-events: none !important;
}

#content-btn .btn {
  margin-top: 20px;
}

@media only screen and (max-width: 428px) {
  .slide-arrow.prev-arrow,
  .slide-arrow.next-arrow {
    top: 106%;
  }
  #content-btn .btn {
    margin-top: 50px;
  }
}

.carLineup_txt span.kerning_car_lineup {
  /* プロポーショナルメトリクスを有効にする指定 */
  /* font-feature-settings: "palt" 1; */
  /* letter-spacing: -.01em; */
  font-weight: 700;
  font-size: clamp(0.875rem, 0.83rem + 0.23vw, 1rem);
}