@charset "UTF-8";
/*
    Template: swell
    Theme Name: SWELL CHILD
    Theme URI: https://swell-theme.com/
    Description: SWELLの子テーマ
    Version: 1.0.0
    Author: LOOS WEB STUDIO
    Author URI: https://loos-web-studio.com/

    License: GNU General Public License
    License URI: http://www.gnu.org/licenses/gpl.html
*/




/* ===== PRICE IMAGE ONLY ===== */
.price-images {
  display: flex;
  justify-content: center;
  gap: 24px;
  margin-top: 40px;
}

/* 画像ボタン */
.price-image {
  width: 320px;           /* ← 2枚目くらいのサイズ感 */
  max-width: 45%;
  position: relative;
  display: block;
  text-decoration: none;
}

/* 画像 */
.price-image img {
  width: 100%;
  height: auto;
  display: block;
}

/* DAY / NIGHT テキスト */
.price-image__label {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 18px;
  letter-spacing: 0.15em;
  color: #fff;
  background: rgba(0,0,0,0.15);
}

/* hover（ほんのり） */
.price-image:hover .price-image__label {
  background: rgba(0,0,0,0.25);
}

/* ===== SP ===== */
@media (max-width: 768px) {
  .price-images {
    flex-direction: column;
    gap: 20px;
  }

  .price-image {
    width: 100%;
    max-width: 100%;
  }
}





/* ==============================================
   SWELL タブブロック｜ボタン風デザイン（最終調整版）
   ============================================== */

/* --- タブ全体の配置・間隔 --- */
.c-tabList {
  justify-content: center;
  gap: 40px;
}

/* --- タブボタン共通 --- */
.c-tabList__button {
  border-radius: 999px;
  padding: 14px 44px;
  font-size: 15px;
  font-weight: 500;
  letter-spacing: 0.08em;
  background-color: #ECE7E3;
  color: #322518;
  border: 1px solid #c7b400;
  transition: all 0.25s ease;
  position: relative;
}

/* --- ホバー時 --- */
.c-tabList__button:hover {
  background-color: #c7b400;
  color: #322518;
}

/* --- 選択中（アクティブ） --- */
.c-tabList__button[aria-selected="true"] {
  background-color: #c7b400 !important;
  color: #322518 !important;
  border-color: #c7b400;
}

/* --- 吹き出し三角・下線など完全削除 --- */
.c-tabList__button::before,
.c-tabList__button::after {
  display: none !important;
  content: none !important;
}

/* --- コンテンツとの距離をほんのり --- */
.c-tabBody {
  border: none;
  padding-top: 32px;
}

/* --- スマホのみサイズ調整 --- */
@media (max-width: 768px) {
  .c-tabList {
    gap: 12px;
  }

  .is-style-balloon .c-tabList__button {
    padding: 10px 20px;
    font-size: 12px;
    min-width: 140px;    /* ← 同じ幅に揃える */
    text-align: center;
  }
}





.price-cards {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 32px;
}

.price-card {
  position: relative;
  padding: 36px 32px;
  border: 1px solid #fff;
  text-align: center;
  color: #fff;
  min-height: 340px; /* ← 高くしすぎない */
}

.icon-box {
  width: 40px;
  height: 40px;
  background: #fff;
  margin: 0 auto 20px;
}

.price-card h3 {
  letter-spacing: 0.12em;
  margin-bottom: 20px;
}

.price {
  font-size: 32px;
  font-weight: 600;
  margin-bottom: 12px;
}

.price span {
  font-size: 16px;
}

.note {
  margin-bottom: 24px;
  font-size: 14px;
  opacity: 0.85;
}

.list {
  list-style: none;
  padding: 0;
  margin: 0;
}

.list li {
  margin-bottom: 14px;
  font-size: 15px;
  position: relative;
  padding-left: 22px;
  text-align: left;
  display: inline-block;
}

.list li::before {
  content: "✓";
  position: absolute;
  left: 0;
}

/* BAR用 */
.bar-note {
  margin: 24px 0 18px;
  font-size: 15px;
}

.late {
  text-align: center;
  font-size: 14px;
  opacity: 0.85;
}

/* おすすめバッジ */
.badge {
  position: absolute;
  top: 16px;
  right: 16px; /* ← 中央に来ない */
  background: #000;
  color: #fff;
  font-size: 12px;
  padding: 6px 10px;
}






.cta-box {
  max-width: 1100px;
  margin: 0 auto;
  background: #fff;
  border: 1px solid #322518;
  padding: 32px;
  display: flex;
  align-items: center;
  gap: 32px;
  color: #322518;
}

/* 🔴 黄色は固定幅にする */
.cta-left {
  width: 180px;                 /* ← 超重要 */
  flex-shrink: 0;               /* ← 縮まない */
  background: #E0C04C;
  clip-path: polygon(0 0, 85% 0, 100% 50%, 85% 100%, 0 100%);
  padding: 18px 20px;
  display: flex;
  align-items: center;
  gap: 10px;
  font-weight: bold;
  white-space: nowrap;
}

.cta-left img {
  width: 26px;
}

/* 中央だけが伸びる */
.cta-center {
  flex: 1;
}

/* 以下そのまま */
.price-row {
  display: flex;
  align-items: center;
  gap: 12px;
}

.label {
  min-width: 72px;
}

.price {
  font-size: 20px;
  position: relative;
}

.price.strike::after {
  content: "";
  position: absolute;
  left: -4px;
  right: -4px;
  top: 50%;
  height: 3px;
  background: #D61F18;
  transform: rotate(-6deg);
}

.line {
  height: 1px;
  background: #322518;
  margin: 14px 0;
}

.note {
  font-size: 12px;
  color: #D61F18;
  margin-top: 6px;
}

.cta-right {
  display: flex;
  align-items: center;
  gap: 24px;
}

.zero {
  font-size: 64px;
  font-weight: bold;
  color: #D61F18;
  line-height: 1;
}

.zero span {
  font-size: 24px;
  margin-left: 4px;
}

.cta-btn {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  padding: 16px 28px;
  background: linear-gradient(180deg, #117050, #06402D);
  color: #fff;
  border-radius: 999px;
  text-decoration: none;
  font-weight: bold;
  white-space: nowrap;
}

.cta-btn img {
  width: 26px;
}







.left-brown-bg::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 35%;
    height: 100%;
    background-color: #221714;
    z-index: 0;
}

.left-brown-bg {
    position: relative;
}

.left-brown-bg > * {
    position: relative;
    z-index: 1;
}




.yellow-curved-bg::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: #BBA311;
    clip-path: polygon(0 0, 0 0%, 25% 100%, 100% 100%, 100% 0);
    z-index: 0;
}





/* コンテナ */
.flow-boxes {
    max-width: 900px;
    margin: 0 auto;
    padding: 40px 20px;
}

/* 左側に斜めカットのあるボックス */
.diagonal-cut-box {
    position: relative;
    background-color: #322518;
    color: #c8c8c8;
    clip-path: polygon(3% 0, 100% 0, 100% 100%, 0 100%, 0 15%);
    padding: 15px 40px 15px 80px;
    margin-bottom: 30px;
    display: flex;
    align-items: flex-start;
    gap: 50px;
    letter-spacing: 0.1em;
    height: 125px;
    box-sizing: border-box;
    overflow: hidden;
}

/* 番号 */
.box-number {
    font-size: 52px;
    font-weight: bold;
    color: #BBA311;
    font-family: 'Georgia', 'Times New Roman', serif;
    line-height: 1;
    flex-shrink: 0;
    letter-spacing: 0.05em;
    margin-top: 8px;
    margin-bottom: 0 !important;
    padding: 0 !important;
}

/* コンテンツエリア */
.box-content {
    flex: 1;
    padding-top: 5px;
    display: flex;
    flex-direction: column;
    justify-content: center;
    height: 100%;
}

/* タイトル */
.box-title {
    font-size: 33px;
    margin: 0 0 12px 0 !important;
    padding: 0 !important;
    color: #c8c8c8;
    font-weight: normal;
    letter-spacing: 0.15em;
    line-height: 1.2;
}

/* タイトルの接尾語 */
.title-suffix {
    font-size: 18px;
    margin-left: 8px;
}

/* 本文 */
.box-text {
    font-size: 14px;
    line-height: 1.6;
    margin: 0 !important;
    padding: 0 !important;
    letter-spacing: 0.08em;
}

/* 黄色のテキスト */
.yellow-text {
    color: #BBA311;
}

/* スマホ */
@media (max-width: 768px) {
    .flow-boxes {
        padding: 20px 12px; /* ← 左右余白を縮小 */
    }
    .diagonal-cut-box {
        padding: 12px 16px 12px 16px; /* ← 左パディングを縮小 */
        gap: 16px; /* ← 番号とテキストの間隔を縮小 */
        height: auto;
        min-height: 80px;
        clip-path: polygon(5% 0, 100% 0, 100% 100%, 0 100%, 0 20%); /* ← SP用に調整 */
        align-items: center; /* ← 縦中央揃え */
    }
    .box-number {
        font-size: 36px; /* ← 縮小 */
        margin-top: 0;
    }
    .box-title {
        font-size: 18px; /* ← 縮小 */
        margin: 0 0 6px 0 !important;
        letter-spacing: 0.08em;
    }
    .title-suffix {
        font-size: 14px;
    }
    .box-text {
        font-size: 12px; /* ← 縮小 */
        line-height: 1.5;
    }
}






/* ===============================
   OPENING CAMPAIGN
================================= */
.oc-wrap{
  width:100vw;
  margin-left:calc(50% - 50vw);
  margin-right:calc(50% - 50vw);
  background:#221714;
  overflow:hidden;
}
.oc-inner{
  display:flex;
  width:100%;
  height:480px;
}
/* ===============================
   LEFT
================================= */
.oc-left{
  width:50%;
  padding:60px 50px;
  color:#fff;
  display:flex;
  flex-direction:column;
  align-items:center;
  text-align:center;
  justify-content:center;
}
/* タイトル */
.oc-title{
  font-size:34px;
  font-weight:600;
  color:#BBA311;
  letter-spacing:.12em;
  position:relative;
  margin-bottom:35px;
}
.oc-title:after{
  content:"";
  position:absolute;
  bottom:-8px;
  left:50%;
  transform:translateX(-50%);
  width:440px;
  max-width:120%;
  height:2px;
  background:#BBA311;
}
/* サブ */
.oc-sub{
  font-size:20px;
  letter-spacing:.17em;
  margin-bottom:30px;
}
/* ===============================
   PRICE AREA
================================= */
.oc-price-area{
  display:flex;
  align-items:center;
  gap:40px;
  margin-bottom:25px;
}
.oc-price-list{
  display:flex;
  flex-direction:column;
}
.oc-row{
  display:flex;
  justify-content:space-between;
  width:240px;
  padding:10px 0;
  border-bottom:1px solid rgba(255,255,255,.3);
  font-size:19px;
}
.amount{
  position:relative;
  display:inline-block;
  font-weight:600;
}
.slash{
  position:absolute;
  width:100%;
  height:2px;
  background:#D61F18;
  top:50%;
  left:0;
  transform:translateY(-50%) rotate(-15deg);
}
.oc-note{
  margin-top:8px;
  font-size:12px;
  opacity:.85;
}
/* 0円 */
.oc-zero{
  font-size:95px;
  font-weight:800;
  color:#E10600;
  line-height:1;
  white-space:nowrap;
}
/* ===============================
   BUTTON
================================= */
.oc-btn{
  background:#E6E6E6;
  color:#221714;
  padding:12px 28px;
  border-radius:50px;
  text-decoration:none;
  font-weight:600;
  max-width:420px;
  width:100%;
  display:inline-block;
  margin-top:10px;
  font-size:14px;
  white-space:normal;
  text-align:center;
  line-height:1.4;
  word-break:keep-all;
}
/* ===============================
   RIGHT
================================= */
.oc-right{
  width:50%;
}
.oc-right img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}
/* ===============================
   iPad Air 最適化（769px〜1024px）
================================= */
@media (min-width:769px) and (max-width:1024px){
  .oc-left{
    padding:40px 30px;
  }
  .oc-title{
    font-size:28px;
  }
  .oc-sub{
    font-size:16px;
  }
  .oc-price-area{
    gap:25px;
  }
  .oc-row{
    width:200px;
    font-size:15px;
  }
  .oc-zero{
    font-size:64px;
  }
  .oc-btn{
    font-size:13px;
    padding:10px 20px;
  }
}
/* ===============================
   SP（768px以下）
================================= */
@media(max-width:768px){
  .oc-inner{
    flex-direction:column;
    height:auto;
  }
  .oc-left,
  .oc-right{
    width:100%;
  }
  .oc-right{
    height:240px;
  }
  .oc-price-area{
    flex-direction:row;
    gap:20px;
  }
  .oc-row{
    width:200px;
    font-size:14px;
  }
  .oc-zero{
    font-size:56px;
  }
  .oc-title{
    font-size:32px;               /* ← 拡大 */
    line-height:1.6;
    text-decoration:underline;
    text-decoration-color:#BBA311;
    text-underline-offset:10px;   /* ← 調整 */
    text-decoration-thickness:2px;
  }
  .oc-title:after{
    display:none !important;
  }
  .oc-sub{
    font-size:15px;
  }
}








/* デフォルト（SP・iPadは普通表示） */
.video-crop{
  position:relative;
  width:100%;
}

/* PCだけ縦をトリミング */
@media (min-width:1025px){

  .video-crop{
    height:420px;       /* ← 好きな高さに調整 */
    overflow:hidden;
  }

  .video-crop iframe,
  .video-crop video{
    position:absolute;
    top:50%;
    left:50%;
    width:100%;
    height:100%;
    transform:translate(-50%,-50%);
    object-fit:cover;
  }

}





/* 左上だけ角丸にする専用クラス */
.left-top-radius {
  position: relative;
  overflow: hidden; /* 角丸を確実に効かせる */
  border-radius: 80px 0 0 0; /* 左上だけR */
}

/* 念のためSWELL内部ラッパーにも継承 */
.left-top-radius > .l-container,
.left-top-radius > .wp-block-group__inner-container {
  border-radius: inherit;
}







/* このアコーディオンだけ＋をゴールドにする */
.golf-acc .__icon--closed::before,
.golf-acc .__icon--opened::before {
  color: #BBA311 !important;
}






/* ヘッダー内を縦中央揃えに */
#header .l-header__inner {
    height: 80px !important;
    align-items: center !important;
    display: flex !important;
    justify-content: space-between !important;
    max-width: 100% !important;
    padding-left: 30px !important;
    padding-right: 30px !important;
}

/* ロゴサイズ */
#header .l-header__logo img {
    height: 80px !important;
    width: auto !important;
}

@media (max-width: 768px) {
    #header .l-header__inner.l-container {
        padding-left: 0px !important;
        padding-right: 0px !important;
    }

    #header .l-header__logo {
        position: absolute !important;
        left: 18px !important;  /* ← 少し右に */
        top: 50% !important;
        transform: translateY(-60%) !important;  /* ← 少し上に */
        margin-top: 0 !important;
    }
}


#fix_header .l-fixHeader__inner {
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    padding-left: 40px !important;
    padding-right: 30px !important;
    max-width: 100% !important;
    width: 100% !important;
}






/* ===== メインビジュアル ===== */

/* PC：右寄せ */
@media (min-width: 769px) {
    .p-mainVisual__textLayer .p-blogParts {
        display: flex !important;
        flex-direction: column !important;
        align-items: flex-end !important;
    }
    .p-mainVisual__textLayer .p-blogParts .swell-block-button {
        align-self: flex-end !important;
        width: 100% !important;
        text-align: right !important;
    }
    .p-mainVisual__textLayer .p-blogParts .swell-block-button__link {
        min-width: 400px !important;
    }
    .sp-only {
        display: none !important;
    }
}

/* スマホ */
@media (max-width: 768px) {
    .p-mainVisual__textLayer {
        padding-top: 80px !important;
    }
    .p-mainVisual__textLayer .p-blogParts h1 {
        font-size: 1.4rem !important;
        letter-spacing: 0.05em !important;
    }
    .p-mainVisual__textLayer .p-blogParts p {
        font-size: 0.8rem !important;
    }
    .p-mainVisual__textLayer .swell-block-button {
        text-align: right !important;
    }
    .p-mainVisual__textLayer .p-blogParts .swell-block-button__link {
        min-width: 280px !important;
        font-size: 0.85rem !important;
    }
}

/* ===== メインビジュアルボタン ===== */
.white-button.is-style-btn_normal .swell-block-button__link {
    background-color: transparent !important;
    color: #ffffff !important;
    border: 2px solid #ffffff !important;
    text-shadow: none !important;
}

.white-button.is-style-btn_normal .swell-block-button__link:hover {
    background-color: #ffffff !important;
    color: #322518 !important;
    border-color: #ffffff !important;
    text-shadow: none !important;
    box-shadow: none !important;
}

/* ホバー時の影を消す */
.p-mainVisual__textLayer .p-blogParts .swell-block-button__link {
    text-shadow: none !important;
}

.p-mainVisual__textLayer .p-blogParts .swell-block-button__link:hover {
    text-shadow: none !important;
    box-shadow: none !important;
}






.p-mainVisual__textLayer .p-blogParts h1 {
    font-family: 'Oswald', sans-serif !important;
}






/* ヘッダーウィジェット横並び */
.w-header__inner .textwidget {
    display: flex !important;
    align-items: center !important;
    gap: 16px !important;
}




.c-gnav a::after {
    bottom: -10px !important; /* ← 数値を大きくすると下に */
}




/* スマホ固定ボタン */
@media screen and (max-width: 768px) {
    body {
        padding-bottom: 70px !important;
    }
    .p-fixBtnWrap {
        bottom: 5.5em !important;
    }
    #fixed-bottom-menu {
        display: block;
        position: fixed;
        left: 0;
        bottom: 0;
        width: 100%;
        z-index: 999;
        background-color: #322518;
        padding: 8px 16px;
    }
    #fixed-bottom-menu .round-button.is-style-btn_normal .swell-block-button__link {
        border-radius: 999px !important;
        background-color: #BBA311 !important;
        color: #c8c8c8 !important;
        border-color: #BBA311 !important;
    }
}

/* PCでは非表示 */
@media screen and (min-width: 769px) {
    #fixed-bottom-menu {
        display: none !important;
    }
}


