﻿@charset "utf-8";

:root {
  --cp-red: #CA1D1D;
  --cp-base: #F7F2EA;
  --cp-ivory: #FCF9F4;
  --cp-accent: #8A6B52;
  --cp-text: #2F2A26;
  --cp-border: #5B4A3B;

  --heading-line-width: 48px;
  --heading-line-gap: 16px;

  --section-pad-y: 64px;
  --section-gap: 32px;
  --howto-width-pc: 560px;
  --howto-width-sp: 420px;
  --howto-step-indent-pc: calc(3ch + 16px);
  --howto-step-indent-sp: 64px;
}

/* ========================================
   FutureShop Default Override
   - デフォルト看板領域の余白調整
   - ページ標準h1の非表示
======================================== */
.fs-l-main {
  max-width: 100%;
  margin-top: 0;
  padding: 0;
  margin-bottom: 0;
}

h1.fs-c-heading.fs-c-heading--page {
  display: none;
}

/* ========================================
   Main Visual (LP)
======================================== */
section.present-cp-mainVisual {
  display: block !important;
  margin: 0 !important;
  margin-top: -6px !important;
  padding-top: 0 !important;
  width: 100vw;
  margin-left: calc(50% - 50vw) !important;
  margin-right: calc(50% - 50vw) !important;
}

.present-cp-mainVisual {
  height: auto;
  margin-bottom: 0;
  line-height: 0;
}

.present-cp-mainVisual .present-cp-mainVisual-inner {
  display: block !important;
  width: 100%;
  max-width: none !important;
  margin: 0 !important;
  padding: 0 !important;
}

.present-cp-mainVisual .present-cp-mainVisual-inner img {
  display: block !important;
  width: 100% !important;
  max-width: 100% !important;
  height: auto;
  visibility: visible !important;
  opacity: 1 !important;
  margin: 0;
  z-index: 2;
}

/* ========================================
   Base
======================================== */
.present-cp-wrapper {
  width: 100%;
  margin: 0 auto;
  padding: 0 0 56px;
  color: var(--cp-text);
}

.present-cp-wrapper * {
  box-sizing: border-box;
}

.present-cp-wrapper ul,
.present-cp-wrapper li {
  margin: 0;
  padding: 0;
  list-style: none;
}

.present-cp-wrapper img {
  display: block;
  max-width: 100%;
  height: auto;
  margin-left: auto;
  margin-right: auto;
}

/* ========================================
   Headings
======================================== */
.present-cp-wrapper h1,
.present-cp-wrapper h2 {
  margin: 0 auto 36px;
  text-align: center;
  line-height: 1.3;
}

.present-cp-wrapper h1 {
  position: relative;
  display: inline-block;
  font-size: clamp(24px, 3.3vw, 42px);
}

.present-cp-wrapper h2 {
  font-size: clamp(24px, 3.3vw, 42px);
}

.present-cp-heading {
  position: relative;
  display: inline-block;
  margin-bottom: 36px;
  padding: 0;
}

.present-cp-heading--primary {
  color: var(--cp-red);
}

.present-cp-heading--secondary {
  color: var(--cp-accent);
}

.present-cp-heading::before,
.present-cp-heading::after {
  content: "";
  position: absolute;
  top: 50%;
  width: var(--heading-line-width);
  height: 5px;
  border-top: 1px solid currentColor;
  border-bottom: 1px solid currentColor;
}

.present-cp-heading::before {
  left: calc(-1 * (var(--heading-line-width) + var(--heading-line-gap)));
}

.present-cp-heading::after {
  right: calc(-1 * (var(--heading-line-width) + var(--heading-line-gap)));
}

/* 商品について見出し位置調整 */
.present-cp-sec--products .present-cp-heading--secondary {
  margin-top: 32px;
  margin-bottom: 48px;
}

/* ========================================
   Blocks / Layout
======================================== */
.present-cp-sec {
  width: 100%;
}

/* wrapper外まで背景を全幅化 */
.present-cp-wrapper > .present-cp-sec,
.present-cp-wrapper > .present-cp-cv-btn {
  width: 100vw;
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);
}

.present-cp-sec--content {
  margin: 0;
  padding: var(--section-pad-y) 16px;
  text-align: center;
}

.present-cp-sec--overview {
  padding-top: calc(var(--section-pad-y) + 16px);
  background: var(--cp-base);
}

.present-cp-sec--products {
  padding-top: 0;
  background: #fff;
}

.present-cp-sec--howto {
  background: var(--cp-ivory);
}

.present-cp-sec--announcement {
  background: var(--cp-base);
}

.present-cp-sec--winners {
  background: #fff;
}

.present-cp-sec--notes {
  background: var(--cp-ivory);
}

/* products(ディバイダーあり)以外は要素間余白を統一 */
.present-cp-sec--content:not(.present-cp-sec--products) > * {
  margin-top: 0;
  margin-bottom: 0;
}

.present-cp-sec--content:not(.present-cp-sec--products) > * + * {
  margin-top: var(--section-gap);
}

/* 中央カラム幅 */
.present-cp-sec--content > * {
  max-width: 960px;
  margin-left: auto;
  margin-right: auto;
}

.present-cp-sec--products > .custom-shape-divider-top-1724337054 {
  max-width: none;
}

.present-cp-sec--content ul {
  max-width: 920px;
  margin-left: auto;
  margin-right: auto;
}

.present-cp-sec--content :is(li, p) {
  font-size: clamp(14px, 1.7vw, 20px);
  line-height: 1.8;
}

.present-cp-sec--content li {
  max-width: 900px;
  margin: 0 auto 16px;
}

.present-cp-sec--content a {
  text-align: center;
}

/* キャンペーン概要 / 商品 / 応募方法は中央組み */
:is(.present-cp-sec--overview, .present-cp-sec--products, .present-cp-sec--howto) li {
  text-align: center;
}

/* ========================================
   商品について
======================================== */
.present-cp-product {
  display: grid;
  grid-template-columns: minmax(260px, 420px) minmax(320px, 1fr);
  grid-template-areas:
    "image title"
    "image desc"
    "image link";
  align-items: start;
  column-gap: 40px;
  row-gap: 10px;
  margin: 0 auto 56px;
}

.present-cp-product + .present-cp-product {
  margin-top: 48px;
}

.present-cp-sec--products .present-cp-product:last-of-type {
  margin-bottom: 24px;
}

.present-cp-product-media {
  grid-area: image;
}

.present-cp-product-media a,
.present-cp-product-media img {
  display: block;
  width: 100%;
  height: auto;
}

.present-cp-product-body > h2 {
  grid-area: title;
  margin: 0 0 16px;
  font-size: clamp(24px, 2.2vw, 34px);
  line-height: 1.35;
  text-align: left;
}

.present-cp-product-body > p {
  grid-area: desc;
  margin: 0;
  text-align: left;
}

.present-cp-product-link {
  grid-area: link;
  margin-top: 18px;
  text-align: center;
}

.present-cp-product--02 {
  grid-template-areas:
    "title image"
    "desc image"
    "link image";
}

.present-cp-howto-image {
  width: min(50%, var(--howto-width-pc));
}

.present-cp-howto-steps {
  max-width: var(--howto-width-pc);
  margin: 0 auto;
  padding-left: var(--howto-step-indent-pc);
  text-align: left;
}

.present-cp-howto-step + .present-cp-howto-step {
  margin-top: 20px;
}

.present-cp-howto-step-title {
  margin: 0 0 6px;
  color: var(--cp-red);
  font-weight: 700;
  letter-spacing: 0.03em;
}

.present-cp-howto-step p {
  margin: 0;
}

/* ========================================
   当選発表 / 当選者の方へ / 注意事項
======================================== */
.present-cp-sec--announcement > p,
.present-cp-sec--winners > p {
  max-width: 920px;
  margin-left: auto;
  margin-right: auto;
  text-align: left;
  overflow-wrap: anywhere;
  word-break: break-word;
}

.present-cp-sec--announcement ul li,
.present-cp-sec--winners ul li,
.present-cp-sec--notes ul li {
  max-width: 920px;
  line-height: 1.2;
  text-align: left;
}

.present-cp-sec--announcement p + ul,
.present-cp-sec--winners p + ul {
  margin-top: 32px;
}

/* ========================================
   Deadline
======================================== */
.present-cp-deadline {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 14px;
  padding: 8px 16px;
  background: var(--cp-red);
  color: #fff;
}

.present-cp-deadline-label {
  display: inline-block;
  min-width: 124px;
  padding: 5px 14px;
  border-radius: 999em;
  background: #fff;
  color: #8f7b66;
  font-size: 14px;
  font-weight: 700;
  line-height: 1;
  text-align: center;
  white-space: nowrap;
}

.present-cp-deadline-date {
  font-size: 28px;
  font-weight: 700;
  line-height: 1.2;
  letter-spacing: 0.02em;
  white-space: nowrap;
}

/* ========================================
   Nav Grid
======================================== */
.present-cp-sec--nav {
  padding: 0;
  background: #fff;
}

.present-cp-sec--nav > ul {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.present-cp-sec--nav li {
  border-right: 1px solid var(--cp-border);
  border-bottom: 1px solid var(--cp-border);
}

.present-cp-sec--nav li:nth-child(3n) {
  border-right: 0;
}

.present-cp-menu-btn {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 2px;
  min-height: 94px;
  color: var(--cp-accent);
  font-weight: 700;
  font-size: clamp(22px, 2.2vw, 40px);
  line-height: 1.35;
  letter-spacing: 0.02em;
  text-align: center;
  text-decoration: none;
  white-space: nowrap;
  transition: color 0.3s;
}

.present-cp-menu-btn:hover {
  color: var(--cp-border);
}

.present-cp-menu-btn-arrow {
  margin-top: 2px;
  font-size: 0.65em;
  line-height: 1;
  color: #c29a7a;
}

/* ========================================
   Buttons
======================================== */
.present-cp-cta-btn {
  display: inline-block;
  min-width: 560px;
  padding: 16px 40px;
  border: 1px solid var(--cp-red);
  border-radius: 100px;
  background: var(--cp-red);
  color: #fff !important;
  font-size: 32px;
  font-weight: 700;
  line-height: 1.2;
  text-align: center;
  text-decoration: none;
  white-space: nowrap;
  transition: 0.3s;
}

.present-cp-cta-btn:hover {
  background: #fff;
  color: var(--cp-red) !important;
}

.present-cp-cta-btn--product {
  min-width: 220px;
  padding: 10px 26px;
  border-color: var(--cp-accent);
  background: var(--cp-accent);
  font-size: 16px;
  line-height: 1.3;
}

.present-cp-cta-btn--product:hover {
  border-color: var(--cp-accent);
  background: #fff;
  color: var(--cp-accent) !important;
}

.present-cp-cv-btn {
  width: 100%;
  display: flex;
  justify-content: center;
  align-items: center;
  padding: 0 16px 56px;
}

.present-cp-sec--products + .present-cp-cv-btn {
  background: #fff;
  padding-top: 0;
  padding-bottom: 72px;
}

.present-cp-sec--howto .present-cp-cv-btn {
  padding: 16px 0 0;
}

.present-cp-contact-btn-wrap {
  display: flex;
  justify-content: center;
  margin-top: 40px;
}

.present-cp-contact-btn {
  min-width: 0;
  width: auto;
  padding: 12px 28px;
  border: 1px solid var(--cp-accent);
  border-radius: 100px;
  background: var(--cp-accent);
  color: #fff !important;
  font-size: 16px;
  transition: 0.3s;
}

.present-cp-contact-btn:hover {
  background: #fff;
  color: var(--cp-accent) !important;
  border-color: var(--cp-accent);
}

/* ========================================
   Utility
======================================== */
.present-cp-text-accent {
  color: var(--cp-red);
}

.present-cp-pc-only {
  display: block;
}

.present-cp-sp-only {
  display: none;
}

/* ========================================
   Divider / Page Top
======================================== */
.custom-shape-divider-top-1724337054 {
  position: relative;
  top: 0;
  width: 100vw;
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);
  overflow: hidden;
  line-height: 0;
  transform: rotate(180deg);
}

.custom-shape-divider-top-1724337054 svg {
  display: block;
  width: 100%;
  height: 74px;
}

.custom-shape-divider-top-1724337054 .shape-fill {
  fill: var(--cp-ivory);
}

/* ========================================
   SP
======================================== */
@media only screen and (max-width: 768px) {
  .present-cp-wrapper {
    padding: 0 0 36px;
  }

  .present-cp-wrapper h1 {
    margin-bottom: 28px;
    padding: 0 34px;
    font-size: clamp(21px, 7vw, 34px);
  }

  .present-cp-wrapper h2 {
    margin-bottom: 28px;
    font-size: clamp(16px, 5.2vw, 26px);
  }

  .present-cp-deadline {
    gap: 6px;
    padding: 7px 8px;
  }

  .present-cp-deadline-label {
    min-width: auto;
    padding: 5px 8px;
    font-size: 10px;
  }

  .present-cp-deadline-date {
    font-size: clamp(14px, 4.5vw, 20px);
    line-height: 1.1;
  }

  .present-cp-sec--nav > ul {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .present-cp-sec--nav li {
    border-right: 1px solid var(--cp-border);
  }

  .present-cp-sec--nav li:nth-child(3n) {
    border-right: 1px solid var(--cp-border);
  }

  .present-cp-sec--nav li:nth-child(2n) {
    border-right: 0;
  }

  .present-cp-menu-btn {
    min-height: 72px;
    font-size: clamp(16px, 4.6vw, 22px);
    line-height: 1.25;
  }

  .present-cp-sec--content {
    padding: 44px 14px;
  }

  .present-cp-sec--overview {
    padding-top: 60px;
  }

  .present-cp-sec--content:not(.present-cp-sec--products) > * + * {
    margin-top: 24px;
  }

  .present-cp-sec--products {
    padding-top: 0;
  }

  .present-cp-sec--content li {
    margin-bottom: 14px;
  }

  .present-cp-cv-btn {
    padding: 0 14px 44px;
  }

  .present-cp-sec--products .present-cp-product:last-of-type {
    margin-bottom: 20px;
  }

  .present-cp-sec--products + .present-cp-cv-btn {
    padding-bottom: 52px;
  }

  .present-cp-sec--howto .present-cp-cv-btn {
    padding: 12px 0 0;
  }

  .present-cp-contact-btn-wrap {
    margin-top: 32px;
  }

  .present-cp-product {
    display: flex;
    flex-direction: column;
    gap: 10px;
    margin-bottom: 36px;
  }

  .present-cp-product + .present-cp-product {
    margin-top: 48px;
  }

  .present-cp-product-body {
    display: contents;
  }

  .present-cp-product-body > h2 {
    order: 1;
    width: 100%;
    margin: 0 0 16px;
    text-align: center;
  }

  .present-cp-product-media {
    order: 2;
  }

  .present-cp-product-body > p {
    order: 3;
    max-width: 32em;
    margin: 0 auto;
    text-align: left;
  }

  .present-cp-product-link {
    order: 4;
    text-align: center;
  }

  .present-cp-howto-image {
    width: 80%;
  }

  .present-cp-howto-steps {
    max-width: var(--howto-width-sp);
    padding-left: var(--howto-step-indent-sp);
  }

  .present-cp-howto-step + .present-cp-howto-step {
    margin-top: 16px;
  }

  .present-cp-cta-btn {
    min-width: 0;
    width: min(92vw, 520px);
    padding: 14px 24px;
    font-size: 22px;
    line-height: 1.25;
  }

  .present-cp-sp-only {
    display: block;
  }

}

