@charset "UTF-8";

/*!
Theme Name: Cocoon Child
Description: Cocoon専用の子テーマ
Theme URI: https://wp-cocoon.com/
Author: わいひら
Author URI: https://nelog.jp/
Template:   cocoon-master
Version:    1.1.3
*/

/************************************
** 子テーマ用のスタイルを書く
************************************/
/*必要ならばここにコードを書く*/

/************************************
** レスポンシブデザイン用のメディアクエリ
************************************/
/*1023px以下*/
@media screen and (max-width: 1023px){
  /*必要ならばここにコードを書く*/
}

/*834px以下*/
@media screen and (max-width: 834px){
  /*必要ならばここにコードを書く*/
}

/*480px以下*/
@media screen and (max-width: 480px){
  /*必要ならばここにコードを書く*/
}


/* ========================================
   Kresta LINEページ専用デザイン
   対象：固定ページ LINE / page-id-15
======================================== */


/* ========================================
   ページ全体背景・不要要素非表示
======================================== */

.page-id-15,
.page-id-15 body,
.page-id-15 .container,
.page-id-15 .content,
.page-id-15 .content-in,
.page-id-15 .main,
.page-id-15 .article,
.page-id-15 .entry-content {
  background: #202028 !important;
}

.page-id-15 .header-container,
.page-id-15 .navi,
.page-id-15 .breadcrumb,
.page-id-15 .date-tags,
.page-id-15 .author-info,
.page-id-15 .under-entry-content,
.page-id-15 .pager-post-navi,
.page-id-15 .sidebar,
.page-id-15 .sns-share,
.page-id-15 .sns-follow,
.page-id-15 .footer,
.page-id-15 .author-box,
.page-id-15 .entry-footer {
  display: none !important;
}


/* ========================================
   メインレイアウト
======================================== */

.page-id-15 .main {
  width: 100% !important;
  max-width: 100% !important;
}

.page-id-15 .content-in {
  display: block !important;
}

.page-id-15 .article {
  max-width: 760px;
  margin: 0 auto;
  padding: 42px 18px 56px;
  background: transparent;
}


/* ========================================
   LINEカード本体
======================================== */

.page-id-15 .kresta-line-page {
  text-align: center;
  color: #e8e4dc;
}

.page-id-15 .kresta-line-card {
  max-width: 560px;
  margin: 0 auto;
  padding: 34px 34px 38px;
  background: #181820;
  border: 1px solid rgba(210,195,150,0.18);
  box-shadow: 0 14px 34px rgba(0,0,0,0.28);
}


/* ========================================
   ロゴ
======================================== */

.page-id-15 .kresta-line-brand-logo {
  margin: 0 auto 26px;
}

.page-id-15 .kresta-line-brand-logo img {
  width: 230px;
  max-width: 62%;
  height: auto;
  display: block;
  margin: 0 auto;
}


/* ========================================
   LINEタイトル
======================================== */

.page-id-15 .kresta-line-logo {
  margin-bottom: 12px;
  color: #06c755;
  font-size: 24px;
  font-weight: 700;
  letter-spacing: 0.08em;
}

.page-id-15 .kresta-line-card h1 {
  margin: 0 0 22px;
  font-family: Georgia, "Times New Roman", serif;
  font-size: 25px;
  font-weight: 400;
  letter-spacing: 0.06em;
  color: #f2eee4;
}


/* ========================================
   説明文
======================================== */

.page-id-15 .kresta-line-lead {
  margin: 0 0 24px;
  font-size: 14px;
  line-height: 2;
  color: #d8d3c8;
}


/* ========================================
   QRコード
======================================== */

.page-id-15 .kresta-line-qr img {
  width: 220px;
  max-width: 100%;
  height: auto;
  display: block;
  margin: 0 auto 16px;
  padding: 10px;
  background: #fff;
}

.page-id-15 .kresta-line-caption {
  margin: 0 0 28px;
  font-size: 15px;
  font-weight: 600;
  line-height: 1.8;
  color: #f0eadf;
}


/* ========================================
   ガイドカード
======================================== */

.page-id-15 .kresta-line-guide {
  max-width: 430px;
  margin: 0 auto 18px;
  padding: 22px 20px 24px;
  border: 1px solid rgba(210,195,150,0.18);
  background: rgba(255,255,255,0.035);
  border-radius: 8px;
}

.page-id-15 .kresta-line-guide-pc {
  background: rgba(0,0,0,0.16);
}

.page-id-15 .kresta-line-guide-title {
  margin: 0 0 10px;
  color: #d9c58c;
  font-size: 15px;
  font-weight: 600;
}

.page-id-15 .kresta-line-guide-text {
  margin: 0 0 18px;
  font-size: 13px;
  line-height: 2;
  color: #d2cec5;
}


/* ========================================
   ボタン共通
======================================== */

.page-id-15 .kresta-line-btn,
.page-id-15 .kresta-line-btn-sub,
.page-id-15 .kresta-back-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto;
  text-align: center;
  text-decoration: none;
  font-weight: 600;
  line-height: 1;
  border-radius: 999px;
  box-sizing: border-box;
  transition: 0.2s ease;
}


/* ========================================
   LINE追加ボタン
======================================== */

.page-id-15 .kresta-line-btn {
  width: 260px;
  height: 64px;
  background: #06c755;
  color: #fff !important;
  box-shadow: 0 8px 20px rgba(6,199,85,0.22);
  font-size: 17px;
}


/* ========================================
   PC版LINEボタン
======================================== */

.page-id-15 .kresta-line-btn-sub {
  width: 250px;
  height: 58px;
  border: 1px solid #d9c58c;
  color: #d9c58c !important;
  background: transparent;
  font-size: 16px;
}


/* ========================================
   戻るボタン
======================================== */

.page-id-15 .kresta-line-links {
  margin-top: 28px;
}

.page-id-15 .kresta-back-btn {
  width: 310px;
  height: 58px;
  border: 1px solid rgba(210,195,150,0.55);
  color: #f4efe3 !important;
  background: transparent;
  font-size: 15px;
  letter-spacing: 0.04em;
}


/* ========================================
   ボタンホバー
======================================== */

.page-id-15 .kresta-line-btn:hover,
.page-id-15 .kresta-line-btn-sub:hover,
.page-id-15 .kresta-back-btn:hover {
  opacity: 0.9;
  transform: translateY(-1px);
}


/* ========================================
   注記
======================================== */

.page-id-15 .kresta-line-note {
  margin: 24px 0 0;
  font-size: 12.5px;
  line-height: 1.9;
  color: #aaa39a;
}


/* ========================================
   スマホ調整
======================================== */

@media screen and (max-width: 600px) {

  .page-id-15 .article {
    padding: 26px 12px 46px;
  }

  .page-id-15 .kresta-line-card {
    padding: 26px 16px 30px;
  }

  .page-id-15 .kresta-line-brand-logo img {
    width: 200px;
    max-width: 72%;
  }

  .page-id-15 .kresta-line-card h1 {
    font-size: 21px;
    line-height: 1.5;
  }

  .page-id-15 .kresta-line-qr img {
    width: 210px;
  }

  .page-id-15 .kresta-line-btn,
  .page-id-15 .kresta-line-btn-sub,
  .page-id-15 .kresta-back-btn {
    width: 100%;
    max-width: 320px;
  }

}

/* 空ボタンが出た場合の保険 */
.page-id-15 a.kresta-line-btn:empty,
.page-id-15 a.kresta-line-btn-sub:empty,
.page-id-15 a.kresta-back-btn:empty {
  display: none !important;
}

/* ========================================
   Kresta LINEページ Cocoonページタイトル非表示
======================================== */

.page-id-15 .entry-title {
  display: none !important;
}

/* PC版LINEボタン 文字位置微調整 */

.page-id-15 .kresta-line-btn-sub {
  padding-bottom: 1px;
}

/* ========================================
   Kresta LINEページ スマホ下部ボタン非表示
======================================== */

.page-id-15 .mobile-menu-buttons,
.page-id-15 .mobile-footer-menu-buttons,
.page-id-15 .mobile-menu-buttons-container,
.page-id-15 .mobile-button-fmb,
.page-id-15 .navi-menu-content,
.page-id-15 .search-menu-content,
.page-id-15 .sidebar-menu-content {
  display: none !important;
}

.page-id-15 {
  padding-bottom: 0 !important;
}

/* ========================================
   Kresta LINEページ Cocoonスマホ固定メニュー完全非表示
======================================== */

.page-id-15 .mobile-menu-buttons,
.page-id-15 .mobile-menu-buttons * ,
.page-id-15 .mobile-footer-menu-buttons,
.page-id-15 .mobile-footer-menu-buttons * ,
.page-id-15 .mobile-menu-button,
.page-id-15 .mobile-menu-button * ,
.page-id-15 .footer-mobile-buttons,
.page-id-15 .footer-mobile-buttons * ,
.page-id-15 .fixed-bottom-menu,
.page-id-15 .fixed-bottom-menu * {
  display: none !important;
  visibility: hidden !important;
  opacity: 0 !important;
  height: 0 !important;
}

/* ========================================
   Kresta LINE 説明文調整
======================================== */

.page-id-15 .kresta-line-lead {
  margin: 0 0 28px;
  font-size: 16px;
  line-height: 2.15;
  color: #e2ddd3;
  letter-spacing: 0.03em;
}


/* ========================================
   Kresta LINE 文字階層・読みやすさ調整
======================================== */

.page-id-15 .kresta-line-logo {
  margin-bottom: 10px;
  font-size: 22px;
  color: #06c755;
}

.page-id-15 .kresta-line-card h1 {
  margin: 0 0 22px;
  font-size: 22px;
  line-height: 1.45;
  color: #f1eee6;
}

.page-id-15 .kresta-line-lead {
  max-width: 390px;
  margin: 0 auto 30px;
  font-size: 14.5px;
  line-height: 2.05;
  color: #d6d1c8;
  letter-spacing: 0.02em;
}

.page-id-15 .kresta-line-lead br + br {
  display: block;
  content: "";
  margin-top: 8px;
}

.page-id-15 .kresta-line-card {
  color: #d6d1c8;
}


/* ========================================
   Kresta LINE 大型背景ペンダント
======================================== */

.page-id-15 .kresta-line-card {
  position: relative;
  overflow: hidden;
}

.page-id-15 .kresta-line-card::before {
  content: "";
  position: absolute;

  left: -95px;
  top: -83px;

  width: 690px;
  height: 940px;

  background-image: url("https://www.kresta.jp/wp-content/uploads/2026/05/ChatGPT-Image-2026年5月27日-19_16_34_comp.png");

  background-repeat: no-repeat;
  background-position: center top;
  background-size: contain;

  opacity: 0.82;

  mask-image: linear-gradient(
    to bottom,
    transparent 0%,
    black 12%,
    black 82%,
    transparent 100%
  );

  -webkit-mask-image: linear-gradient(
    to bottom,
    transparent 0%,
    black 12%,
    black 82%,
    transparent 100%
  );

  pointer-events: none;
  z-index: 0;
}

.page-id-15 .kresta-line-card > * {
  position: relative;
  z-index: 1;
}


/* ========================================
   Kresta LINE 説明文パネル
======================================== */

.page-id-15 .kresta-line-message-panel {
  max-width: 460px;

  margin: 0 auto 26px;

  padding: 22px 18px;

  border: 1px solid rgba(217,197,140,0.28);

  background:
    linear-gradient(
      rgba(12,12,18,0.36),
      rgba(12,12,18,0.36)
    ),
    repeating-linear-gradient(
      45deg,
      rgba(217,197,140,0.085) 0,
      rgba(217,197,140,0.085) 1px,
      transparent 1px,
      transparent 9px
    );

  backdrop-filter: blur(1px);
}

.page-id-15 .kresta-line-message-panel p {
  margin: 0;

  font-size: 15px;

  line-height: 1.9;

  letter-spacing: 0.03em;

  color: #f0ece4;
}

.page-id-15 .kresta-line-divider {
  width: 90px;
  height: 1px;

  margin: 18px auto;

  background: rgba(217,197,140,0.55);
}

/* ========================================
   Kresta LINE スマホ表示 最終調整
======================================== */

@media screen and (max-width: 600px) {

  .page-id-15 .kresta-line-message-panel {
    width: 86%;
    max-width: 86%;
    padding: 22px 16px;
  }

  .page-id-15 .kresta-line-message-panel p {
    font-size: 12.6px !important;
    line-height: 1.85 !important;
    letter-spacing: -0.04em !important;
  }

  .page-id-15 .kresta-line-card h1 {
    font-size: 20px;
    line-height: 1.45;
  }

}

/* ========================================
   スマホ時のみ改行
======================================== */

br.sp-only {
  display: none !important;
}

@media screen and (max-width: 600px) {

  br.sp-only {
    display: block !important;
    content: "";
    margin-top: 0;
  }

}

/* ========================================
   Kresta LINE スマホ下段文だけ改行調整
======================================== */

@media screen and (max-width: 600px) {

  .page-id-15 .kresta-line-contact-text {
    font-size: 12.2px !important;
    line-height: 1.85 !important;
    letter-spacing: -0.08em !important;
    white-space: nowrap;
  }

}

/* ========================================
   Kresta LINE 上段文章 スマホ最終調整
======================================== */

.page-id-15 .kresta-line-info-text {
  white-space: normal;
}

@media screen and (max-width: 600px) {

  .page-id-15 .kresta-line-info-text {
    font-size: 12.2px !important;
    line-height: 1.85 !important;
    letter-spacing: -0.08em !important;
  }

}