@charset "utf-8";

/*
*********************************************************
campaign-contents
*********************************************************
*/
#campaign-contents {
  max-width: 100%;
  margin: 0 auto;
}

/* chrome 画像・グラフィック文字のぼやけ対策 */
@media (-webkit-min-device-pixel-ratio: 0) and (min-resolution: .001dpcm) {
  #campaign-contents img {
    image-rendering: -webkit-optimize-contrast;
  }
}

/* safari 画像 デフォルト値 */
@media (-webkit-min-device-pixel-ratio: 0) {

  _::-webkit-full-page-media,
  _:future,
  :root #campaign-contents img {
    image-rendering: auto;
  }
}

#campaign-contents .maximg {
  width: 100%;
  height: auto
}

/*
***************************************************************
明朝 font
***************************************************************
*/
.lead-font-mincho {
  font-family: "Zen Old Mincho", "游明朝", YuMincho, "Hiragino Mincho ProN W3", "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", serif;
  font-weight: 400;
  font-style: normal;
}

.lead-font-mincho-m {
  font-family: "Zen Old Mincho", "游明朝", YuMincho, "Hiragino Mincho ProN W3", "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", serif;
  font-weight: 500;
  font-style: normal;
}

.lead-font-mincho-b {
  font-family: "Zen Old Mincho", "游明朝", YuMincho, "Hiragino Mincho ProN W3", "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", serif;
  font-weight: 600;
  font-style: normal;
}

/*
*********************************************************
#section-kv
*********************************************************
*/
#section-kv {
  position: relative;
}

#section-kv .photo {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  aspect-ratio: 1440/610;
}

#section-kv picture,
#section-kv picture img {
  width: 100%;
  height: auto;
  display: block;
}

/* ----------------- h1-box ----------------- */
#section-kv .h1-box {
  position: relative;
  margin: 0 auto;
  padding: 56px 16px 40px;
}

#section-kv .h1-box-inner {
  max-width: 1240px;
  margin: 0 auto;
}

#section-kv .h1-box h1 {
  max-width: 1130px;
  margin: 0 auto;
  padding: 0 0 var(--size16);
}

#section-kv .h1-box .note {
  color: #1d2087;
  font-size: 2rem;
  text-align: center;
  line-height: 1.8;
  margin: 0 auto;
}

@media (min-width: 769px) and (max-width: 1280px) {
  #section-kv .h1-box .note br.sp-only {
    display: block !important;
  }
}

@media (min-width: 769px) and (max-width: 1024px) {
  #section-kv .h1-box .note {
    font-size: 1.6rem;
  }
}

/* ---------------------------------------------  */
/* --------------------- SP --------------------  */
/* ---------------------------------------------  */

@media print, screen and (max-width:768px) {
  #section-kv .h1-box {
    padding: 20px 0;
  }

  #section-kv .h1-box-inner {
    display: block;
    align-items: center;
    width: 100%;
    max-width: inherit;
    margin: 0;
  }

  #section-kv .h1-box h1 {
    width: 88%;
    max-width: inherit;
    padding: 0;
  }

  #section-kv .h1-box .note {
    text-align: center;
    font-size: var(--size12);
    font-weight: bold;
    padding: 16px 0 0;
  }
}

@media (max-width:375px) {
  #section-kv .h1-box .note {
    font-size: 10px;
  }
}

/*
*********************************************************
#section-gift
*********************************************************
*/
#section-gift {
  max-width: 1360px;
  margin: 0 auto;
}

#section-gift .gift-inner {
  padding: 0 var(--size16);
}

#section-gift h2 {
  background-color: #1d2087;
  text-align: center;
  padding: var(--size24);
}

#section-gift h2 img {
  max-width: 240px;
}

/* --------------- summary-box --------------- */
#section-gift .summary-box {
  background-color: #f5f6f4;
  color: #1d2087;
  text-align: center;
  padding: var(--size40);
}

#section-gift .summary-box h3 {
  font-size: 3.4rem;
  line-height: 1.6;
  letter-spacing: -0.06em;
}

#section-gift .summary-box h4 {
  font-size: 3.4rem;
  letter-spacing: -0.02em;
}

@media (min-width: 769px) and (max-width: 1024px) {
  #section-gift .summary-box h3 {
    font-size: 2.6rem;
  }

  #section-gift .summary-box h4 {
    font-size: 2.6rem;
  }
}

@media (min-width: 769px) and (max-width: 1280px) {
  #section-gift .summary-box br.sp-only {
    display: block !important;
  }
}

/* ---------------------------------------------  */
/* --------------------- SP --------------------  */
/* ---------------------------------------------  */
@media screen and (max-width: 768px) {
  #section-gift {
    max-width: inherit;
    margin: 0;
  }

  #section-gift .gift-inner {
    padding: 0;
  }

  #section-gift h2 {
    padding: var(--size16);
  }

  #section-gift h2 img {
    width: 40%;
    max-width: inherit;
  }

  #section-gift .summary-box {
    padding: var(--size16);
  }

  #section-gift .summary-box h3 {
    font-size: 1.8rem;
  }

  #section-gift .summary-box h4 {
    font-size: 1.8rem;
    padding-top: var(--size16);
  }
}

@media screen and (max-width: 360px) {
  #section-gift h2 {
    line-height: 1;
  }

  #section-gift h2 img {
    width: 30%;
    height: auto;
  }

  #section-gift .summary-box h3 {
    font-size: 1.6rem;
  }

  #section-gift .summary-box h4 {
    font-size: 1.6rem;
    padding-top: var(--size16);
  }
}

/* --------------- summary-car-box --------------- */
#section-gift .summary-car-box {
  display: flex;
  justify-content: center;
  align-items: center;
  max-width: 1130px;
  gap: 36px;
  margin: 0 auto;
  padding: var(--size40) 0;
}

#section-gift .summary-car-box .box {
  flex: 1;
  max-width: 547px;
  text-align: center;
}

#section-gift .summary-car-box .box h5 {
  background-color: #1d2087;
  color: #fff;
  font-size: 2.6rem;
  font-weight: bold;
  letter-spacing: 0.02em;
  padding: var(--size8);
}

#section-gift .summary-car-box .box h6 {
  border: 2px solid #1d2087;
  color: #1d2087;
  font-weight: bold;
  font-size: 5.0rem;
  padding: var(--size8);
}

#section-gift .summary-car-box .box h6 span {
  font-size: 3.2rem;
  line-height: 1.6;
  letter-spacing: 0.02em;
}

@media (min-width: 769px) and (max-width: 1024px) {
  #section-gift .summary-car-box .box h6 {
    font-size: 3.0rem;
  }

  #section-gift .summary-car-box .box h6 span {
    font-size: 2.2rem;
  }
}

/* ---------------------------------------------  */
/* --------------------- SP --------------------  */
/* ---------------------------------------------  */
@media screen and (max-width: 768px) {
  #section-gift .summary-car-box {
    display: block;
    max-width: inherit;
    padding: var(--size16);
  }

  #section-gift .summary-car-box .passenger-car {
    padding-bottom: var(--size16);
  }

  #section-gift .summary-car-box .box {
    max-width: inherit;
  }

  #section-gift .summary-car-box .box h5 {
    font-size: 1.6rem;
    padding: var(--size8);
  }

  #section-gift .summary-car-box .box h6 {
    font-size: 2.6rem;
  }

  #section-gift .summary-car-box .box h6 span {
    font-size: 1.8rem;
  }
}

@media screen and (max-width: 321px) and (max-width: 360px) {
  #section-gift .summary-box h3 {
    font-size: 1.6rem;
  }

  #section-gift .summary-box h4 {
    font-size: 1.6rem;
  }
}

@media screen and (max-width: 321px) {
  #section-gift .summary-box h3 {
    font-size: 1.4rem;
  }

  #section-gift .summary-box h4 {
    font-size: 1.4rem;
  }
}

/* --------------- slider --------------- */
/* ------------------------------------  */
/* ---------------- 共通 ---------------  */
/* ------------------------------------  */
#section-gift .gift-container {
  max-width: 1130px;
  margin: 20px auto;
  padding: 0;
}

#section-gift .category-box {
  max-width: 1130px;
  border: 2px solid #1d2087;
  margin-bottom: 48px;
  padding: 0;
}

#section-gift .category-box.digitalgifts {
  padding: 0 16px;
}

#section-gift .category-box h3 {
  position: relative;
  max-width: 266px;
  margin: -12px auto;
}

#section-gift .category-title {
  position: relative;
  text-align: center;
  margin: 30px auto;
}

#section-gift .category-title img {
  max-width: 640px;
}

#section-gift .pc-slider,
#section-gift .sp-image,
#section-gift .single-image,
#section-gift .sp-nav-buttons {
  display: none;
}

#section-gift .photo-box {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100%;
  height: 100%;
}

#section-gift .h5-box h5 {
  color: #1d2087;
  font-weight: bold;
  font-size: 2.0rem;
  text-align: center;
  margin: 0 auto;
  padding: var(--size12);
}

#section-gift .button-wrapper {
  display: flex;
  justify-content: center;
  gap: 10px;
}

#section-gift .digitalgifts .button-wrapper {
  padding-top: var(--size32);
}

#section-gift .link-button {
  display: block;
  width: 260px;
  background-color: #1d2087;
  color: #fff;
  font-size: 1.6rem;
  font-weight: bold;
  text-align: center;
  line-height: 2em;
  text-decoration: none;
  border-radius: 30px;
  transition: background-color 0.3s;
  margin: 0;
  padding: 5px;
}

#section-gift .link-button span.name {
  font-size: 2rem;
}

#section-gift .link-button span.price {
  font-size: 1.2rem;
}

#section-gift a[target="_blank"]:not(.icn-none):after {
  background: url(/assets/images/icn_blank_white.svg) no-repeat center center / contain;
}

#section-gift .link-button:hover {
  background-color: #0056b3;
}

#section-gift .note-box {
  color: #333;
  font-size: 1.0rem;
  text-align: left;
  margin: 0 auto;
  padding-left: var(--size16);
  padding-bottom: var(--size16);
}

@media (min-width: 769px) and (max-width: 1024px) {
  #section-gift .note-box {
    padding-top: var(--size8);
  }
}

/* --- ボタンの三角デザイン --- */
#section-gift .slider-nav::before,
#section-gift .sp-nav-button::before {
  content: '';
  position: absolute;
  top: 50%;
  left: 50%;
  width: 0;
  height: 0;
  border-style: solid;
}

/* 左向きの三角 (◀) */
#section-gift .slider-nav.prev::before,
#section-gift #sp-prev-btn::before {
  border-width: 10px 18px 10px 0;
  border-color: transparent white transparent transparent;
  transform: translate(-60%, -50%);
}

/* 右向きの三角 (▶) */
#section-gift .slider-nav.next::before,
#section-gift #sp-next-btn::before {
  border-width: 10px 0 10px 18px;
  border-color: transparent transparent transparent white;
  transform: translate(-40%, -50%);
}

/* ---------------------------------------------  */
/* --------------------- SP --------------------  */
/* ---------------------------------------------  */
@media screen and (max-width: 768px) {
  #section-gift .gift-container {
    position: relative;
    overflow: hidden;
    max-width: 100%;
    margin: 10px auto 20px;
  }

  #section-gift .category-wrapper {
    display: flex;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    scroll-behavior: smooth;
    scrollbar-width: none;
    padding: 12px 0 0 46px;
    scroll-snap-type: x mandatory;
    scroll-padding-left: 46px !important;
    scroll-padding-right: 46px !important;
  }

  #section-gift .category-wrapper .category-spacer {
    flex: 0 0 46px !important;
    width: 46px !important;
    margin: 0 !important;
    visibility: hidden;
    pointer-events: none;
    height: 1px;
  }

  /* 左側のフェードオーバーレイ */
  #section-gift .gift-container::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 50px;
    height: 100%;
    background: linear-gradient(to right, white 0%, rgba(255, 255, 255, 0.2) 100%);
    pointer-events: none;
    z-index: 2;
  }

  /* 右側のフェードオーバーレイ */
  #section-gift .gift-container::after {
    content: "";
    position: absolute;
    top: 0;
    right: 0;
    width: 50px;
    height: 100%;
    background: linear-gradient(to left, white 0%, rgba(255, 255, 255, 0.2) 100%);
    pointer-events: none;
    z-index: 2;
  }

  #section-gift .gift-container.hide-right-fade::after {
    opacity: 0 !important;
    visibility: hidden !important;
    transition: opacity 0.3s ease, visibility 0.3s ease;
  }

  #section-gift .category-wrapper::-webkit-scrollbar {
    display: none;
  }

  #section-gift .category-box {
    position: relative;
    width: 100%;
    scroll-snap-align: center;
    margin-bottom: 0;
    flex: 0 0 78%;
    margin: 0 4.5%;
  }

  #section-gift .sp-image,
  #section-gift .single-image {
    display: block;
  }

  #section-gift .sp-image .photo-box {
    width: 100%;
    height: auto;
    padding: 0 var(--size16);
  }

  #section-gift .button-wrapper {
    flex-direction: column;
    align-items: center;
    padding: 0 var(--size16);
  }

  #section-gift .sp-nav-buttons {
    display: block;
  }

  #section-gift .sp-nav-button {
    position: fixed;
    top: 50%;
    transform: translateY(-50%);
    width: 40px;
    height: 40px;
    background-color: rgba(0, 0, 0, 0.4);
    border: none;
    border-radius: 50%;
    cursor: pointer;
    z-index: 100;
    visibility: hidden;
    opacity: 0;
    transition: opacity 0.3s ease-in;
  }

  #section-gift .sp-nav-button:disabled {
    opacity: 0.2 !important;
    cursor: not-allowed;
  }

  #section-gift #sp-prev-btn {
    left: 10px;
  }

  #section-gift #sp-next-btn {
    right: 10px;
  }

  #section-gift .category-box h3 {
    max-width: 70%;
    margin: -8px auto;
  }

  #section-gift .category-title {
    margin: 24px auto var(--size16);
  }

  #section-gift .category-title img {
    width: 80%;
    max-width: inherit;
  }

  #section-gift .h5-box h5 {
    font-size: 1.4rem;
    line-height: 1;
    padding: var(--size12);
  }

  /* --- スライダー以外の単体画像のスタイル --- */
  #section-gift .single-image .photo-box {
    position: relative;
    overflow: hidden;
    display: flex;
    justify-content: center;
    align-items: center;
    width: 100%;
    height: auto;
    margin: 0;
    padding: 0;
  }

  #section-gift .single-image .photo-box picture {
    width: 100%;
    height: auto;
  }

  #section-gift .single-image .photo-box .overlay-image {
    position: absolute;
    top: 7.3%;
    left: 50%;
    transform: translateX(-50%);
    width: 70%;
    height: auto;
    z-index: 10;
  }

  #section-gift .link-button {
    line-height: 2.4em;
  }

  #section-gift .gourmet .link-button {
    line-height: 2.2em;
  }

  #section-gift .digitalgifts .button-wrapper {
    padding-top: var(--size16);
  }

  #section-gift .note-box {
    padding-top: var(--size16);
  }

  #section-gift .digitalgifts .note-box {
    padding-left: 0;
    padding-bottom: 0;
  }

  #section-gift .link-button:hover {
    background-color: #1d2087;
  }
}


@media screen and (min-width: 761px) and (max-width: 768px) {
  #section-gift .category-box {
    flex: 0 0 94%;
    margin: 0 2%;
  }

  #section-gift .gift-container::before,
  #section-gift .gift-container::after {
    width: 45px;
  }
}

@media screen and (min-width: 600px) and (max-width: 760px) {
  #section-gift .category-box {
    flex: 0 0 94%;
    margin: 0 2%;
  }

  #section-gift .gift-container::before,
  #section-gift .gift-container::after {
    width: 30px;
  }
}

@media screen and (min-width: 376px) and (max-width: 599px) {
  #section-gift .category-box {
    flex: 0 0 94%;
    margin: 0 3%;
  }

  #section-gift .gift-container::before,
  #section-gift .gift-container::after {
    width: 26px;
  }
}

@media screen and (min-width: 322px) and (max-width: 375px) {
  #section-gift .category-box {
    flex: 0 0 92%;
    margin: 0 2.5%;
  }

  #section-gift .gift-container::before,
  #section-gift .gift-container::after {
    width: 28px;
  }

  #section-gift .link-button {
    width: 220px;
    font-size: 1.4rem;
  }
}

@media screen and (max-width: 321px) {
  #section-gift .category-box {
    flex: 0 0 92%;
    margin: 0 2.5%;
  }

  #section-gift .gift-container::before,
  #section-gift .gift-container::after {
    width: 30px;
  }

  #section-gift .link-button {
    width: 200px;
    font-size: 1.2rem;
    border-radius: 30px;
  }

  #section-gift .link-button span.name {
    font-size: 1.4rem;
  }

  #section-gift .link-button span.price {
    font-size: 1rem;
  }
}

/* ---------------------------------------------  */
/* --------------------- PC --------------------  */
/* ---------------------------------------------  */
@media screen and (min-width: 769px) {
  #section-gift .pc-slider,
  #section-gift .single-image {
    display: block;
  }

  /* --- Swiperコンテナ全体のスタイル --- */
  #section-gift .pc-slider.swiper {
    position: relative;
    width: 100%;
    max-width: 1130px;
    height: 340px;
    margin: 0 auto;
    overflow: hidden;
  }

  #section-gift .pc-slider.swiper .swiper-slide {
    width: 50.88495575%;  /* (575 / 1130) * 100 */
    max-width: 575px;
    height: 100%;
    flex-shrink: 0;
  }

  #section-gift .pc-slider.swiper .swiper-slide img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
  }

  /* --- ナビゲーションボタンのスタイル --- */
  #section-gift .pc-slider.swiper .swiper-button-next,
  #section-gift .pc-slider.swiper .swiper-button-prev {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    width: 50px;
    height: 50px;
    background-color: rgba(0, 0, 0, 0.4);
    border: none;
    border-radius: 50%;
    cursor: pointer;
    transition: opacity 0.3s ease;
    z-index: 5;
  }

  #section-gift .pc-slider.swiper .swiper-button-next:hover,
  #section-gift .pc-slider.swiper .swiper-button-prev:hover {
    opacity: 0.7;
  }

  #section-gift .pc-slider.swiper .swiper-button-prev {
    left: 25%;
  }

  #section-gift .pc-slider.swiper .swiper-button-next {
    right: 25%;
  }

  #section-gift .swiper-button-next::after,
  #section-gift .swiper-button-prev::after {
    display: none;
  }

  /* --- スライダー以外の単体画像のスタイル --- */
  #section-gift .single-image .photo-box {
    position: relative;
    overflow: hidden;
    display: flex;
    justify-content: center;
    align-items: center;
    max-width: 1040px;
    height: 339px;
    margin: 0 auto;
  }

  #section-gift .single-image .photo-box picture {
    min-width: 1040px;
    height: 339px;
  }

  #section-gift .single-image .photo-box .overlay-image {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 326px;
    height: auto;
    z-index: 10;
  }
}

@media (min-width: 769px) and (max-width: 1024px) {
  #section-gift .pc-slider.swiper .swiper-button-prev {
    left: 20%;
  }

  #section-gift .pc-slider.swiper .swiper-button-next {
    right: 20%;
  }
}

/*
*********************************************************
#section-targetcarmodel
*********************************************************
*/
#section-targetcarmodel {
  width: 100%;
  max-width: 1130px;
  margin: 0 auto;
  padding: 0;
}

#section-targetcarmodel h2 {
  background-color: #1d2087;
  color: #fff;
  text-align: center;
  font-size: 2.6rem;
  letter-spacing: 0.06em;
  padding: var(--size16);
}

#section-targetcarmodel .targetcarmodel-inner {
  border: 2px solid #1d2087;
}

@media screen and (max-width: 1170px) {
  #section-targetcarmodel {
    padding: 0 var(--size16);
  }
}

#section-targetcarmodel .targetcarmodel-box {
  color: #1d2087;
  padding: 20px var(--size40);
}

#section-targetcarmodel .targetcarmodel-box dl {
  display: flex;
  align-items: center;
  margin-bottom: var(--size8);
}

#section-targetcarmodel .targetcarmodel-box dt {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 30%;
  border: 1px solid #1d2087;
  background-color: #f5f6f4;
  text-align: center;
  font-size: 2.0rem;
  font-weight: bold;
  margin: 0;
  padding: var(--size16);
}

#section-targetcarmodel .targetcarmodel-box dd {
  width: 70%;
  font-size: 1.8rem;
  font-weight: bold;
  text-align: justify;
  line-height: 1.4;
  letter-spacing: -0.01em;
  padding-left: var(--size24);
  margin: 0;
}

#section-targetcarmodel .targetcarmodel-box dd span {
  font-size: 1.2rem;
  padding-left: 16px;
}

#section-targetcarmodel .targetcarmodel-box dd span.link {
  color: #666;
  font-size: 1.2rem;
  font-weight: normal !important;
  padding-left: var(--size16);
}

#section-targetcarmodel .targetcarmodel-box dd span.link a[target="_blank"]:not(.icn-none):after {
  margin-left: 4px !important;
}

@media screen and (min-width: 769px) and (max-width: 1060px) {
  #section-targetcarmodel .targetcarmodel-box dt {
    padding: 16px 8px;
  }

  #section-targetcarmodel .targetcarmodel-box dd {
    font-size: 1.6rem;
  }
}

@media screen and (min-width: 769px) and (max-width: 1130px) {
  #section-targetcarmodel .targetcarmodel-box dt br.pc-only {
    display: block;
  }

  #section-targetcarmodel .targetcarmodel-box dd br {
    display: none;
  }
}

@media (min-width: 1131px) {
  #section-targetcarmodel .targetcarmodel-box dt br {
    display: none;
  }
}

/* ---------------------------------------------  */
/* --------------------- SP --------------------  */
/* ---------------------------------------------  */
@media screen and (max-width: 768px) {
  #section-targetcarmodel .targetcarmodel-box {
    padding: 20px 16px 8px;
  }

  #section-targetcarmodel h2 {
    font-size: 1.6rem;
  }

  #section-targetcarmodel .targetcarmodel-box dl {
    display: block;
  }

  #section-targetcarmodel .targetcarmodel-box dt {
    width: 100%;
    font-size: 1.6rem;
    padding: var(--size8);
  }

  #section-targetcarmodel .targetcarmodel-box dd {
    width: 100%;
    font-size: 1.2rem;
    letter-spacing: -0.04em;
    text-align: center;
    padding-left: 0;
    padding-top: var(--size8);
  }

  #section-targetcarmodel .targetcarmodel-box dd span.link {
    display: block;
    line-height: 1.6;
    padding-left: var(--size8);
    margin-top: var(--size8);
  }
}

@media screen and (max-width: 320px) {
  #section-targetcarmodel .targetcarmodel-box dt {
    font-size: 1.4rem;
  }

  #section-targetcarmodel .targetcarmodel-box dd {
    font-size: 1.0rem;
    line-height: 1.4;
  }

  #section-targetcarmodel .targetcarmodel-box dd span {
    font-size: 1.0rem;
    font-weight: normal;
    padding-left: var(--size8);
  }

  #section-targetcarmodel .targetcarmodel-box dd span.link {
    font-size: 1.0rem;
  }
}

/*
***************************************************************
#section-ucar
***************************************************************
*/
#section-ucar {
  width: 100%;
  max-width: 1130px;
  margin: 32px auto 40px;
  padding: 0;
}

#section-ucar .ucar-inner {
  border: 2px solid #1d2087;
}

@media screen and (max-width: 1170px) {
  #section-ucar {
    padding: 0 16px;
  }
}

/* --------------- h2-box --------------- */
#section-ucar .h2-box {
  display: flex;
  align-items: center;
  width: 100%;
  margin: 0 auto;
  padding: 24px 0;
}

#section-ucar .h2-box h2 {
  max-width: 526px;
  color: #00266e;
  font-size: 3.8rem;
  font-weight: bold;
  letter-spacing: 0.04em;
  margin: 0 auto;
}

/* --------------- h3-box --------------- */
#section-ucar .h3-box {
  display: flex;
  align-items: center;
  background: #020024;
  background: linear-gradient(260deg, rgba(2, 0, 36, 1) 0%, rgba(9, 9, 121, 1) 0%, rgba(113, 128, 244, 1) 100%);
  width: 100%;
  height: auto;
  margin: 0 auto;
  padding: 24px;
}

#section-ucar .h3-box h3 {
  max-width: 350px;
  height: auto;
  margin: 0 auto;
}

#section-ucar a {
  cursor: pointer;
  -webkit-transition: all .7s;
  transition: all .7s;
}

#section-ucar a:hover {
  opacity: 0.7;
}

/* --------------- btn-wrap --------------- */
#section-ucar .btn-wrap {
  position: relative;
  margin: 0 auto;
  padding: var(--size40);
  z-index: 10;
}

#section-ucar .btn-wrap .btn-nml {
  background-color: #00509c;
  color: #fff;
  border: none;
  min-height: 60px;
  font-size: 1.8rem;
  padding: 6px;
}

#section-ucar .btn-wrap .btn-nml:hover {
  background-color: #0056b3;
  color: #fff;
}

#section-ucar .btn-wrap .btn-nml[target="_blank"]:not(.icn-none):hover:after {
  background: url(/assets/images/icn_blank_white.svg) no-repeat center center / contain;
}

/* -------------------------------------- */
/* ----------------- SP ----------------- */
/* -------------------------------------- */
@media (max-width: 768px) {
  #section-ucar {
    max-width: inherit;
  }

  #section-ucar .ucar-inner {}

  #section-ucar .h2-box {
    padding: 16px 0;
  }

  #section-ucar .h2-box h2 {
    font-size: 1.8rem;
    max-width: inherit;
  }

  #section-ucar .h3-box {
    padding: 16px;
  }

  #section-ucar .h3-box h3 {
    width: 70%;
    text-align: center;
    max-width: inherit;
  }

  #section-ucar .btn-wrap {
    width: 90%;
    padding: var(--size16);
  }

  #section-ucar .btn-wrap .btn-nml {
    width: 100%;
    min-height: 46px;
    font-size: 1.4rem;
    padding: 6px;
  }
}

@media (min-width: 600px) and (max-width: 768px) {
  #section-ucar .h2-box h2 {
    font-size: 3.8rem;
  }
  #section-ucar .btn-wrap .btn-nml {
    min-height: 60px;
    font-size: 2.6rem;
    padding: 6px;
  }
}

/*
***************************************************************
#section-cautions
***************************************************************
*/
#section-cautions {
  overflow: hidden;
  width: 100%;
  max-width: 1130px;
  background-color: #fff;
  margin: 0 auto;
}

@media screen and (max-width: 1170px) {
  #section-cautions {
    padding: 0 16px;
  }
}

#section-cautions .cautions-inner {
  text-align: center;
  margin: 0 auto;
  padding: 0;
}

#section-cautions .cautions-inner p {
  text-align: justify;
  font-size: 1.2rem;
  line-height: 1.8;
}

/* -------------------------------------- */
/* ----------------- SP ----------------- */
/* -------------------------------------- */
@media (max-width: 768px) {
  #section-cautions {
    max-width: inherit;
  }

  #section-cautions .cautions-inner {
    margin: 0;
    padding: 0 0 40px;
  }
}

/*
***************************************************************
#section-related-sites
***************************************************************
*/
#section-related-sites {
  overflow: hidden;
  width: 100%;
  max-width: 1440px;
  margin: 56px auto;
  padding: 0;
}

#section-related-sites .related-sites-inner {
  width: 100%;
  margin: 0;
  padding: 0;
}

/* --------------- related-sites --------------- */
#section-related-sites .related-sites {
  position: relative;
  width: 100%;
  margin: 0 auto;
}

#section-related-sites .related-sites h2 {
  position: relative;
  font-size: 0;
}

#section-related-sites .related-sites a {
  cursor: pointer;
  -webkit-transition: all .7s;
  transition: all .7s;
}

#section-related-sites .related-sites a:hover {
  opacity: 0.7;
}

#section-related-sites .related-sites span {
  position: absolute;
  width: 300px;
  color: #fff;
  font-weight: bold;
  top: 80%;
  left: 60px;
  margin: 0 auto;
}

#section-related-sites .related-sites a[target="_blank"]:not(.icn-none):after {
  content: "";
  display: inline-block;
  vertical-align: middle;
  margin-left: 10px;
  position: absolute;
  right: 8px;
  top: 8px;
}

/* -------------------------------------- */
/* ----------------- SP ----------------- */
/* -------------------------------------- */
@media (max-width: 768px) {
  #section-related-sites {
    max-width: inherit;
    margin: 0 auto;
  }

  #section-related-sites .related-sites-inner {
    max-width: inherit;
    padding: 0;
  }

  #section-related-sites .related-sites h2 {
    position: relative;
    width: 100%;
    font-size: 0;
    top: 0;
    left: 0;
    margin: 0 auto;
  }

  #section-related-sites .related-sites a:hover {
    opacity: 1;
    filter: saturate(100%);
    filter: brightness(100%);
  }
}

/*
***************************************************************
#section-inquiry
***************************************************************
*/
#section-inquiry {
  overflow: hidden;
  width: 100%;
  max-width: 1130px;
  background-color: #fff;
  margin: 0 auto 60px;
  padding: 0 16px;
}

#section-inquiry .inquiry-inner {
  text-align: center;
  margin: 0 auto;
  padding: 0;
}

#section-inquiry .inquiry-wrap {
  display: flex;
  align-items: center;
  column-gap: 16px;
  color: #1d2087;
  font-weight: normal;
  text-align: center;
  margin: 0 auto;
}

#section-inquiry .inquiry-wrap .inquiry {
  font-size: 1.6rem;
  border: 1px solid #1d2087;
  padding: 8px;
}

#section-inquiry .inquiry-wrap .telephone-number {
  font-size: 2rem;
}

#section-inquiry .inquiry-wrap .reception-hours {
  font-size: 1.4rem;
}

@media (min-width: 769px) and (max-width: 1240px) {
  #section-inquiry .inquiry-wrap {
    max-width: 1130px;
    flex-wrap: wrap;
    row-gap: 10px;
    margin: 0 auto;
  }

  #section-inquiry .inquiry-wrap .inquiry {
    width: 100%;
    max-width: 1130px;
    text-align: center;
    margin: 0 auto;
  }

  #section-inquiry .inquiry-wrap .telephone-number,
  #section-inquiry .inquiry-wrap .reception-hours {
    width: calc(50% - (16px / 2));
    text-align: center;
  }
}

@media (min-width: 769px) and (max-width: 900px) {
  #section-inquiry .inquiry-wrap .telephone-number .secretariat {
    display: block;
    margin-bottom: 4px;
  }
}

/* -------------------------------------- */
/* ----------------- SP ----------------- */
/* -------------------------------------- */
@media (max-width: 768px) {
  #section-inquiry .inquiry-wrap {
    display: inline-block;
    width: 100%;
    font-weight: bold;
    margin: 32px 0 0;
  }

  #section-inquiry .inquiry-wrap .inquiry {
    display: inline-block;
    width: 100%;
    font-size: 1.6rem;
    text-align: center;
  }

  #section-inquiry .inquiry-wrap .telephone-number {
    display: inline-block;
    width: 100%;
    font-size: 1.4rem;
    padding-top: 16px;
  }

  #section-inquiry .inquiry-wrap .reception-hours {
    display: inline-block;
    font-size: 1.2rem;
  }
}

@media (max-width: 412px) {
  #section-inquiry .inquiry-wrap .inquiry {
    font-size: calc(0.25vw + 1.8rem);
  }

  #section-inquiry .inquiry-wrap .secretariat {
    font-size: calc(0.25vw + 1.6rem);
  }

  #section-inquiry .inquiry-wrap .telephone-number {
    font-size: calc(0.25vw + 1.4rem);
  }

  #section-inquiry .inquiry-wrap .reception-hours {
    font-size: calc(0.25vw + 1.3rem);
  }
}

@media (max-width: 375px) {
  #section-inquiry .inquiry-wrap .inquiry {
    font-size: calc(0.25vw + 1.4rem);
  }

  #section-inquiry .inquiry-wrap .secretariat {
    font-size: calc(0.25vw + 1.4rem);
  }

  #section-inquiry .inquiry-wrap .telephone-number {
    font-size: calc(0.25vw + 1.2rem);
  }

  #section-inquiry .inquiry-wrap .reception-hours {
    font-size: calc(0.25vw + 1rem);
  }
}

@media (max-width: 360px) {
  #section-inquiry .inquiry-wrap .inquiry {
    font-size: calc(0.25vw + 1.2rem);
  }

  #section-inquiry .inquiry-wrap .secretariat {
    font-size: calc(0.25vw + 1.2rem);
  }

  #section-inquiry .inquiry-wrap .telephone-number {
    font-size: calc(0.25vw + 1.2rem);
  }

  #section-inquiry .inquiry-wrap .reception-hours {
    font-size: calc(0.25vw + 1rem);
  }
}

/*
***************************************************************
btn-page-top
***************************************************************
*/
#campaign-contents .btn-page-top {
  position: fixed;
  right: var(--size48);
  bottom: 80px;
  z-index: 1000;
  width: var(--size48);
  height: var(--size48);
  background-color: #fff;
  border-radius: 50%;
  box-shadow: 0 2px 6px rgba(0, 0, 0, 0.2);
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.3s ease, visibility 0.3s ease;
}

#campaign-contents .btn-page-top.show {
  opacity: 1;
  visibility: visible;
}

#campaign-contents .btn-page-top img {
  width: var(--size24);
  height: var(--size24);
}

@media (max-width: 768px) {
  #campaign-contents .btn-page-top {
    right: var(--size8);
  }
}

/*
***********************************************************
固定追従しないバージョン（通常ページ内）
***********************************************************
*/
#campaign-contents .btn-section {
  background-color: #dde2e6;
  max-width: var(--contentMaxW);
  margin: 0 auto 80px;
}

#campaign-contents .btn-section .btn-wrap-container {
  display: flex;
  justify-content: center;
  gap: 20px;
  padding: 40px 16px;
}

#campaign-contents .btn-section .btn-nml.cv-btn {
  animation: none !important;
}

#campaign-contents .btn-section .btn-wrap-container .btn-wrap {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  max-width: 326px;
  margin-top: 0;
}

#campaign-contents .btn-section .btn-wrap-container .btn-wrap .btn-nml {
  width: 100%;
  text-align: center;
}

@media (max-width: 768px) {
  #campaign-contents .btn-section .btn-wrap-container {
    display: block;
    width: 100%;
    padding: 32px 16px;
  }

  #campaign-contents .btn-section .btn-wrap-container .btn-wrap {
    max-width: inherit;
    padding: 8px 0;
  }
}

/*
**************************************************
  fixed-menu
**************************************************
*/
#fixedBottomBtn {
  position: fixed;
  bottom: -56px;
  left: 0;
  width: 100%;
  background: rgb(255, 255, 255, 0.9);
  box-shadow: 0 -2px 10px rgba(0, 0, 0, 0.1);
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transition: opacity 0.3s ease, bottom 0.3s ease, visibility 0.3s ease;
  z-index: 10;
}

#fixedBottomBtn.show {
  bottom: 0px;
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
}

#fixedBottomBtn .btn-wrap-container {
  display: flex;
  justify-content: center;
  gap: 20px;
  padding: var(--size8);
}

#fixedBottomBtn .btn-wrap-container .btn-wrap {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  max-width: 326px;
  margin-top: 0 !important;
}

#fixedBottomBtn .btn-wrap-container .btn-nml.fixed-btn {
  width: 100%;
  font-size: 1.8rem;
  min-height: var(--size48);
  color: var(--white);
}

#fixedBottomBtn .btn-wrap-container .btn-wrap .btn-ttl {
  font-size: 1.6rem;
  font-weight: bold;
  text-align: center;
  margin-bottom: 5px;
}

@media (max-width: 768px) {
  #fixedBottomBtn .btn-wrap-container {
    flex-wrap: nowrap;
    gap: 8px;
    padding: 8px 0;
  }

  #fixedBottomBtn .btn-wrap-container .btn-wrap {
    max-width: 375px;
  }

  #fixedBottomBtn .btn-wrap-container .btn-nml.fixed-btn {
    font-size: 1.6rem;
    min-height: var(--size24);
  }

  #fixedBottomBtn .btn-wrap-container .btn-wrap .btn-ttl {
    font-size: 1rem;
    margin-bottom: 5px;
  }
}

@media (max-width: 353px) {
  #fixedBottomBtn .btn-wrap-container .btn-wrap .btn-ttl {
    font-size: 0.8rem;
  }
}

/* --------------------- 共通 -------------------- */
#campaign-contents .btn-nml {
  color: var(--white);
}

#campaign-contents .btn-nml:hover {
  color: #014E98;
  opacity: .7;
}

@media (max-width: 768px) {
  #campaign-contents .btn-nml:hover {
    color: #fff;
    opacity: 1;
  }
}

/*
***********************************************************
キャンペーン終了エリア
***********************************************************
*/
/*
  テキストを縦並び＆中央寄せ
  module.css のレイアウトをベースに、余白を最適化
*/
.notice-area-inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
}

.notice-area.alert .notice-area-inner {
  padding-top: 10px;
  padding-bottom: 10px;
}

/*
***********************************************************
シンプルフッターマージン調整
***********************************************************
*/
.footer.footer-simple {
  margin-top: 0;
}

/*
***********************************************************
PRINT
***********************************************************
*/
#campaign-contents img.pr-img {
  display: none !important;
}

@media print {
  #fixedBottomBtn {
    display: none;
  }

  #section-gift .summary-box h3 {
    font-size: 2.0rem;
  }

  #section-gift .summary-box h4 {
    font-size: 2.0rem;
  }

  #section-gift {
    margin-bottom: 2em !important;
  }

  #section-gift .category-wrapper {
    display: block !important;
    overflow-x: visible !important;
    scroll-behavior: auto !important;
    scroll-snap-type: none !important;
    padding: 0 !important;
    width: auto !important;
    max-width: none !important;
    margin: 0 !important;
    background-color: transparent !important;
  }

  #section-gift .category-box {
    display: block !important;
    width: 100% !important;
    flex: 0 0 100% !important;
    margin: 0 0 2em 0 !important;
    padding: 1em !important;
    box-shadow: none !important;
    page-break-inside: avoid !important;
    background-color: #fff !important;
  }

  #section-gift .category-box .sp-image,
  #section-gift .category-box .single-image {
    display: block !important;
  }

  #section-gift .category-box .photo-box img {
    margin: 0 auto 1em !important;
  }

  #section-gift .single-image .photo-box .overlay-image {
    display: block !important;
    position: absolute !important;
    height: auto !important;
    z-index: 10 !important;
    margin: 0 !important;
  }

  #section-gift .category-box .button-wrapper {
    display: flex !important;
    justify-content: center !important;
    margin-top: 1.5em !important;
  }

  #section-gift .category-box .link-button {
    display: inline-block !important;
    border: 1px solid #ccc !important;
    padding: 0.5em 1em !important;
    text-decoration: none !important;
    margin: 0 0.5em !important;
    border-radius: 5px !important;
    font-size: 9pt !important;
    line-height: normal !important;
  }

  .category-box[data-slider="true"] .swiper {
    width: 100% !important;
    overflow: visible !important;
  }

  .category-box[data-slider="true"] .swiper-wrapper {
    display: block !important;
    width: 100% !important;
    transform: none !important;
  }

  .category-box[data-slider="true"] .swiper-slide {
    width: 100% !important;
    margin: 0 0 1.5em 0 !important;
    page-break-inside: avoid !important;
  }

  .swiper-pagination,
  .swiper-button-prev,
  .swiper-button-next {
    display: none !important;
  }

  #section-targetcarmodel .targetcarmodel-box dd {
    font-size: 1.6rem;
  }

  #section-ucar {
    page-break-before: always;
  }

  #section-ucar .h3-box {
    max-width: inherit;
    text-align: center;
  }

  #section-ucar .h3-box h3 {
    max-width: inherit;
    text-align: center;
  }
}



