/*
Theme Name: glue child
Theme URI:
Description: glue の子テーマ
Template: glue_free002
Version: 1.0.0
*/

/* =========================================================
   子テーマCSS
   親テーマCSSは functions.php で読み込む
   ここには差分だけを書く
========================================================= */

/* ---------------------------------------------------------
   共通：透明レイヤーがクリックを邪魔しないようにする
--------------------------------------------------------- */

a::before,
a::after {
  pointer-events: none;
}

/* ---------------------------------------------------------
   PC・スマホ表示切り替え
--------------------------------------------------------- */

@media screen and (min-width: 768px) {
  .pc-only {
    display: block;
    width: 900px;
    max-width: 100%;
    margin: auto;
    background-color: #fcf9df;
  }

  .mobile-only {
    display: none;
  }

  .menu-image {
    margin-right: 5px;
  }

  .sub_menu {
    text-align: right;
  }
}

@media screen and (max-width: 767px) {
  .pc-only {
    display: none;
  }

  .mobile-only {
    display: block;
  }
}

/* ---------------------------------------------------------
   ぷっしゅん：4つのバナー
   PC：4等分
   スマホ：2列
--------------------------------------------------------- */

.flex-container {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  max-width: 900px;
  gap: 10px;
  margin: -40px auto 0;
}

.flex-container a {
  display: block;
  width: 100%;
  line-height: 0;
}

.flex-container img {
  width: 100%;
  height: auto;
  display: block;
}

.copy {
  color: #663300;
  font-weight: bold;
  margin-bottom: 10px;
}

@media screen and (max-width: 767px) {
  .flex-container {
    width: calc(100% - 24px);
    grid-template-columns: repeat(2, minmax(0, 1fr));
    margin: 0 auto;
    gap: 10px;
  }

  .flex-container img {
    width: 100%;
  }
}

/* ---------------------------------------------------------
   スマホ：ヘッダー調整
--------------------------------------------------------- */

@media screen and (max-width: 800px) {
  #header {
    overflow: visible;
    background: #fcf9df;
  }

  #header_top {
    height: 106px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: #fcf9df;
  }

  #header_bottom,
  #global_menu {
    display: none;
  }

  #header_logo {
    position: static;
    transform: none;
    display: flex;
    align-items: center;
    justify-content: center;
  }

  #header_logo img.logo_image.pc,
  #header_logo .logo_image.pc {
    display: none;
  }

  #header_logo img.logo_image.mobile,
  #header_logo .logo_image.mobile {
    display: block;
    width: auto;
    max-width: 250px;
    max-height: 80px;
    height: auto;
    margin: 0 auto;
  }

  #drawer_menu_button {
    display: block;
    position: absolute;
    right: 22px;
    top: 68px;
    width: 46px;
    height: 46px;
    z-index: 100000;
    cursor: pointer;
  }

  #header_search,
  #header_search_button,
  #header_search__button,
  #js-header-search,
  #search_button,
  .search_button,
  .header_search,
  .header_search_button,
  .header_search__button,
  .l-header__search,
  .l-header__search_inner,
  .l-header__search-form,
  .l-header__search-button,
  .submit_label {
    display: none;
    visibility: hidden;
    pointer-events: none;
  }
}

/* ---------------------------------------------------------
   スマホ：ドロワーメニュー
--------------------------------------------------------- */

@media screen and (max-width: 800px) {
  #drawer_menu {
    width: 86vw;
    max-width: 400px;
    background: #fcf9df;
  }

  #drawer_menu ul,
  #drawer_menu li {
    width: 100%;
    margin: 0;
    padding: 0;
  }

  #drawer_menu a {
    display: flex;
    align-items: center;
    width: 100%;
    min-height: 58px;
    padding: 0 24px;
    box-sizing: border-box;
    color: #663300;
    line-height: 1.6;
    text-decoration: none;
  }

  #drawer_menu a::before,
  #drawer_menu a::after {
    display: none;
    content: none;
  }

  #drawer_menu li {
    border-bottom: 1px solid rgba(102, 51, 0, 0.25);
  }

  #drawer_menu form,
  #drawer_menu .searchform,
  #drawer_menu .search_form,
  #drawer_menu .p-widget-search,
  #drawer_menu .widget_search,
  #drawer_menu input[type="search"],
  #drawer_menu input[name="s"],
  #drawer_menu .submit_label {
    display: none;
  }
}

/* ---------------------------------------------------------
   スマホ：本文右切れ防止
--------------------------------------------------------- */

@media screen and (max-width: 800px) {
  #main_content,
  #main_col,
  #page_contents {
    width: 100%;
    max-width: 100%;
    min-width: 0;
    box-sizing: border-box;
  }

  .post_content,
  .post_content.clearfix {
    width: calc(100% - 32px);
    max-width: calc(100% - 32px);
    margin-left: auto;
    margin-right: auto;
    box-sizing: border-box;
  }

  .post_content img,
  .post_content.clearfix img {
    max-width: 100%;
    height: auto;
  }

  .post_content table {
    width: 100%;
    max-width: 100%;
    table-layout: fixed;
  }

  .post_content th,
  .post_content td {
    padding: 12px 8px;
    font-size: 14px;
    line-height: 1.8;
    word-break: break-word;
    overflow-wrap: anywhere;
  }
}


/* =========================================================
   スマホ：s_table 左右バランス修正
   右側の空きすぎを防ぐ
========================================================= */

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

  .s_table {
    width: 100% !important;
    max-width: 100% !important;
    table-layout: fixed !important;
  }

  .s_table th,
  .s_table td {
    width: 50% !important;
    box-sizing: border-box !important;
    padding: 14px 12px !important;
    font-size: 14px !important;
    line-height: 1.9 !important;

    /* 文字を自然に折り返す */
    white-space: normal !important;
    word-break: normal !important;
    overflow-wrap: anywhere !important;
  }

  .s_table th:first-child,
  .s_table td:first-child {
    width: 25% !important;
  }

  .s_table th:nth-child(2),
  .s_table td:nth-child(2) {
    width: 75% !important;
  }

  .s_table p,
  .s_table div,
  .s_table span,
  .s_table a {
    max-width: 100% !important;
    white-space: normal !important;
    word-break: normal !important;
    overflow-wrap: anywhere !important;
  }
}

/* =========================================================
   スマホ：s_table を post_content.clearfix と完全に同じ幅にする
========================================================= */

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

  /* 本文幅を基準にする */
  article#page_contents .post_content.clearfix {
    width: calc(100vw - 32px) !important;
    max-width: calc(100vw - 32px) !important;
    margin-left: auto !important;
    margin-right: auto !important;
    padding: 0 !important;
    box-sizing: border-box !important;
  }

  /* s_table を本文幅いっぱいにする */
  article#page_contents .post_content.clearfix > .s_table,
  article#page_contents .post_content.clearfix .s_table {
    display: block !important;
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    margin: 0 !important;
    padding: 0 !important;
    box-sizing: border-box !important;
    overflow: visible !important;
  }

  /* s_table 内の table も同じ幅にする */
  article#page_contents .post_content.clearfix .s_table table {
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    margin: 0 0 2em 0 !important;
    padding: 0 !important;
    table-layout: fixed !important;
    box-sizing: border-box !important;
    border-collapse: separate !important;
  }

  article#page_contents .post_content.clearfix .s_table tbody,
  article#page_contents .post_content.clearfix .s_table tr {
    width: 100% !important;
    max-width: 100% !important;
    box-sizing: border-box !important;
  }

  /* セル内で自然に折り返す */
  article#page_contents .post_content.clearfix .s_table th,
  article#page_contents .post_content.clearfix .s_table td {
    box-sizing: border-box !important;
    padding: 14px 10px !important;
    font-size: 14px !important;
    line-height: 1.9 !important;
    white-space: normal !important;
    word-break: normal !important;
    overflow-wrap: anywhere !important;
  }

  /* 2列を均等にする */
  article#page_contents .post_content.clearfix .s_table th:first-child,
  article#page_contents .post_content.clearfix .s_table td:first-child {
    width: 25% !important;
  }

  article#page_contents .post_content.clearfix .s_table th:nth-child(2),
  article#page_contents .post_content.clearfix .s_table td:nth-child(2) {
    width: 75% !important;
  }
}

/* =========================================================
   サイトのあゆみ：タブレイアウト完成版 修正版
========================================================= */
/* 注意：
   WordPressがタブボタン周辺にpタグを自動挿入するため、
   .ayumi-tab-buttons p は display:none にしない。
   display:contents で横並びを維持する。
*/

.ayumi-tabs {
  width: 100%;
  max-width: 1000px;
  margin: 40px auto 0;
  box-sizing: border-box;
}

/* タブ横並び */
.ayumi-tab-buttons {
  display: flex !important;
  width: 100%;
  margin: 0;
  padding: 0;
  align-items: flex-end;
  border-bottom: 3px solid #f5a623;
}

/* WordPressが勝手にpを入れた場合も横並びにする */
.ayumi-tab-buttons p {
  display: contents !important;
  margin: 0 !important;
  padding: 0 !important;
}

/* brだけ消す */
.ayumi-tab-buttons br {
  display: none !important;
}

/* タブ共通 */
.ayumi-tab-button {
  display: flex !important;
  align-items: center;
  justify-content: center;
  width: 50% !important;
  min-width: 0;
  height: 54px !important;
  min-height: 54px !important;
  margin: 0 !important;
  padding: 0 12px !important;
  border: none !important;
  border-radius: 12px 12px 0 0;
  box-sizing: border-box;
  background: #fff2a8;
  color: #4a2b00;
  font-family: inherit;
  font-size: 19px !important;
  font-weight: bold;
  line-height: 1.3 !important;
  text-align: center;
  white-space: nowrap;
  cursor: pointer;
  appearance: none;
  -webkit-appearance: none;
}

/* 選択中タブ */
.ayumi-tab-button.is-active {
  background: #f5a623 !important;
  color: #ffffff !important;
}

/* 本文枠 */
.ayumi-panels {
  width: 100%;
  box-sizing: border-box;
  background: #fffdf6;
  border: 1px solid #f5a623;
  border-top: none;
  border-radius: 0 0 14px 14px;
  padding: 34px 42px;
}

/* 本文表示制御 */
.ayumi-panel {
  display: none;
  width: 100%;
  max-width: 100%;
  box-sizing: border-box;
  color: #3d2600;
  font-size: 16px;
  line-height: 1.9;
  overflow-wrap: anywhere;
  word-break: normal;
}

.ayumi-panel.is-active {
  display: block;
}

/* 本文項目 */
.ayumi-panel p {
  margin: 0 0 1.35em;
  padding: 0 0 1.25em;
  border-bottom: 1px dotted #e0c27a;
}

.ayumi-panel p:last-child {
  border-bottom: none;
}

/* スマホ */
@media screen and (max-width: 600px) {
  .ayumi-tabs {
    margin-top: 28px;
  }

  .ayumi-tab-buttons {
    display: block !important;
    border-bottom: none;
  }

  .ayumi-tab-buttons p {
    display: block !important;
  }

  .ayumi-tab-button {
    display: flex !important;
    width: 100% !important;
    height: 48px !important;
    min-height: 48px !important;
    margin: 0 0 8px !important;
    border-radius: 10px !important;
    font-size: 15px !important;
    padding: 0 8px !important;
    white-space: normal;
  }

  .ayumi-panels {
    padding: 20px 16px;
    border-top: 1px solid #f5a623;
    border-radius: 12px;
  }

  .ayumi-panel {
    font-size: 14px;
    line-height: 1.75;
  }

  .ayumi-panel p {
    margin-bottom: 1.1em;
    padding-bottom: 1em;
  }
}

/* =========================================================
   スマホ：ページヘッダー画像を確実に表示
   「満月ポンって何？」ページ対応
========================================================= */

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

  body.page-id-95 #page_header {
    position: relative !important;
    display: block !important;
    width: 100% !important;
    height: 120px !important;
    min-height: 120px !important;
    margin: 0 !important;
    overflow: hidden !important;
    background: none !important;
  }

  body.page-id-95 #page_header img {
    display: block !important;
    visibility: visible !important;
    opacity: 1 !important;

    position: absolute !important;
    top: 0 !important;
    left: 0 !important;

    width: 100% !important;
    height: 100% !important;
    max-width: none !important;

    object-fit: cover !important;
    object-position: center center !important;

    z-index: 1 !important;
  }

  body.page-id-95 #page_header .overlay {
    display: block !important;
    position: absolute !important;
    inset: 0 !important;
    width: 100% !important;
    height: 100% !important;
    background: rgba(0,0,0,0.25) !important;
    z-index: 2 !important;
    pointer-events: none !important;
  }

  body.page-id-95 #archive_headline {
    position: relative !important;
    z-index: 3 !important;
    height: 120px !important;
    min-height: 120px !important;

    display: flex !important;
    align-items: center !important;
    justify-content: center !important;

    background: transparent !important;
  }

  body.page-id-95 #archive_headline .headline {
    color: #ffffff !important;
    text-align: center !important;
    margin: 0 !important;
    font-size: 18px !important;
    line-height: 1.4 !important;
  }
}


/* =========================================================
   PC：joyful.cgi iframe を本文幅いっぱいに広げる
========================================================= */

article#page_contents .post_content.clearfix .responsive-iframe,
article#page_contents .post_content.clearfix iframe[src*="joyful.cgi"],
article#page_contents .post_content.clearfix iframe[src*="joyful"] {
  display: block !important;
  width: 100% !important;
  max-width: 100% !important;
  min-width: 0 !important;
  height: 1200px !important;
  min-height: 1200px !important;
  margin: 0 auto !important;
  padding: 0 !important;
  box-sizing: border-box !important;
  border: none !important;
}

/* =========================================================
   おたのしみコーナー：中央カラム余白調整
========================================================= */

.enjoy_column.enjoy_column_center {
  margin: 0 !important;
  padding: 0 !important;
}

.enjoy_column.enjoy_column_center p {
  margin: 0 !important;
  padding: 0 !important;
}

.enjoy_column.enjoy_column_center img {
  display: block;
  margin: 0 auto;
}

/* =========================================================
   おたのしみコーナー：左右ボタンの重なり防止＋間隔調整
========================================================= */

.enjoy_column:not(.enjoy_column_center) p {
  margin: 0 0 14px !important;
  padding: 0 !important;
  line-height: 1 !important;
}

.enjoy_column:not(.enjoy_column_center) .before-image,
.enjoy_column:not(.enjoy_column_center) .after-image {
  margin: 0 0 14px !important;
  padding: 0 !important;
  height: auto !important;
  line-height: 1 !important;
}

.enjoy_column:not(.enjoy_column_center) .enjoy_btn {
  display: block !important;
  margin: 0 !important;
  padding: 0 !important;
  line-height: 0 !important;
  clear: both;
}

.enjoy_column:not(.enjoy_column_center) .enjoy_btn img {
  display: block !important;
  width: auto;
  height: auto;
  max-width: 100%;
  margin: 0 !important;
}

.enjoy_column:not(.enjoy_column_center) .enjoy_btn + br {
  display: none !important;
}

/* =========================================================
   ポンちゃん物語 固定ページテスト用
========================================================= */

.ponchan-page {
  max-width: 760px;
  margin: 0 auto;
  padding: 24px 10px 50px;
  text-align: center;
  font-family: "メイリオ", Meiryo, sans-serif;
  color: #5a3a1a;
}

.ponchan-select-area {
  max-width: 500px;
  margin: 0 auto 16px;
  text-align: right;
}

.ponchan-select-area select {
  max-width: 100%;
  padding: 6px 8px;
  font-size: 14px;
}

.ponchan-title {
  margin: 10px 0 20px;
  line-height: 1;
}

.ponchan-title img,
.ponchan-card img {
  max-width: 100%;
  height: auto;
}

.ponchan-card {
  max-width: 500px;
  margin: 0 auto 24px;
  padding: 20px 18px 24px;
  background: #fff;
  border: 1px solid #d8c7a3;
  border-radius: 16px;
  box-shadow: 0 4px 12px rgba(90, 58, 26, 0.12);
}

.ponchan-lead {
  font-size: 15px;
  font-weight: bold;
  line-height: 1.8;
  margin: 0 0 12px;
}

.ponchan-text {
  font-size: 15px;
  line-height: 1.8;
  margin: 12px 0 18px;
}

.ponchan-flash-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 8px 18px;
  min-width: 130px;
  min-height: 42px;
  background: #f3a21a;
  color: #ffffff !important;
  border-radius: 999px;
  text-decoration: none !important;
  font-weight: bold;
  font-size: 14px;
  line-height: 1;
  box-shadow: 0 3px 0 #cf850f;
  box-sizing: border-box;
  text-align: center;
}

.ponchan-flash-btn:visited,
.ponchan-flash-btn:hover,
.ponchan-flash-btn:active {
  color: #ffffff !important;
  text-decoration: none;
}

.ponchan-flash-btn:hover {
  opacity: 0.92;
  transform: translateY(1px);
}
@media screen and (max-width: 767px) {
  .ponchan-page {
    padding: 18px 10px 40px;
  }

  .ponchan-select-area {
    text-align: center;
  }

  .ponchan-card {
    padding: 16px 12px 20px;
  }

  .ponchan-lead,
  .ponchan-text {
    font-size: 14px;
  }
}
/* =========================================================
   ポンちゃん物語：FLASHボタン文字色 強制固定
========================================================= */

.ponchan-page .ponchan-card p a.ponchan-flash-btn,
.ponchan-page .ponchan-card p a.ponchan-flash-btn:link,
.ponchan-page .ponchan-card p a.ponchan-flash-btn:visited,
.ponchan-page .ponchan-card p a.ponchan-flash-btn:hover,
.ponchan-page .ponchan-card p a.ponchan-flash-btn:active,
.ponchan-page .ponchan-card p a.ponchan-flash-btn:focus {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  color: #ffffff !important;
  -webkit-text-fill-color: #ffffff !important;
  text-decoration: none !important;
}

.ponchan-page .ponchan-card p a.ponchan-flash-btn span {
  color: #ffffff !important;
  -webkit-text-fill-color: #ffffff !important;
  text-decoration: none !important;
}

/* =========================================================
   ギャラリーページ：テーブル枠なし・背景透明
========================================================= */

.gallery-page {
  background: transparent !important;
}

.gallery-page table,
.gallery-page tbody,
.gallery-page tr,
.gallery-page td {
  border: none !important;
  box-shadow: none !important;
  background: transparent !important;
}

.gallery-page table {
  border-collapse: collapse !important;
}

.gallery-page td[bgcolor="#FF9933"] {
  background: #ff9933 !important;
}

.gallery-page img {
  max-width: 100%;
  height: auto;
  display: inline-block;
}

/* テーマ側の table 背景や余白を打ち消す */
.entry-content .gallery-page table,
.entry-content .gallery-page td,
.post_content .gallery-page table,
.post_content .gallery-page td {
  border: none !important;
  background: transparent !important;
}

/* オレンジ見出しだけ背景を残す */
.entry-content .gallery-page td[bgcolor="#FF9933"],
.post_content .gallery-page td[bgcolor="#FF9933"] {
  background: #ff9933 !important;
}

/* =========================================================
   ギャラリー左メニュー：かわいい角丸ボタン
========================================================= */

.gallery-page td[bgcolor="#FF9933"] {
  background: transparent !important;
}

.gallery-page td[bgcolor="#FF9933"] a,
.gallery-page td[bgcolor="#FF9933"] div,
.gallery-page td[bgcolor="#FF9933"] img {
  background: transparent !important;
}

.gallery-page td[bgcolor="#FF9933"] {
  display: block;
  padding: 0 !important;
}

.gallery-page td[bgcolor="#FF9933"] a {
  display: inline-flex !important;
  align-items: center;
  justify-content: center;
  min-width: 230px;
  min-height: 72px;
  padding: 12px 22px;
  background: #ff9828 !important;
  border-radius: 24px;
  box-shadow: 0 5px 0 #d77712, 0 8px 16px rgba(160, 90, 20, 0.18);
  text-decoration: none !important;
  transition: transform 0.15s ease, box-shadow 0.15s ease, opacity 0.15s ease;
  box-sizing: border-box;
}

.gallery-page td[bgcolor="#FF9933"] a:hover {
  transform: translateY(2px);
  box-shadow: 0 3px 0 #d77712, 0 5px 12px rgba(160, 90, 20, 0.16);
  opacity: 0.95;
}

.gallery-page td[bgcolor="#FF9933"] img {
  max-width: 90%;
  height: auto;
}

/* =========================================================
   マンスリーキャラクターギャラリー
   画像は元サイズのまま・全体幅900px以内
========================================================= */

.gallery-page {
  width: 100%;
  text-align: center;
}

.gallery-page .gallery-inner {
  width: 900px;
  max-width: calc(100% - 24px);
  margin: 0 auto;
}

/* オレンジのタイトル帯 */
.gallery-page .gallery-title {
  width: 100%;
  margin: 0 auto 10px;
  padding: 3px 0;
  background: #ff9933;
  text-align: center;
  box-sizing: border-box;
}

.gallery-page .gallery-title img {
  display: inline-block;
  width: 202px;
  height: 14px;
}

/* 説明文 */
.gallery-page .gallery-message {
  margin: 10px 0 34px;
  color: #ff9900;
  font-size: 14px;
  line-height: 1.7;
  letter-spacing: 0.08em;
}

/* 月ギャラリー全体 */
.gallery-page .monthly-gallery {
  width: 900px;
  max-width: 100%;
  margin: 0 auto;
}

/* 4列 × 3段 */
.gallery-page .monthly-gallery-grid {
  display: grid;
  grid-template-columns: repeat(4, 129px);
  column-gap: 45px;
  row-gap: 22px;
  justify-content: center;
  align-items: start;
}

/* 各月画像：元画像サイズを維持 */
.gallery-page .monthly-gallery-item {
  width: 129px;
  height: 141px;
  line-height: 0;
}

.gallery-page .monthly-gallery-item a {
  display: block;
  width: 129px;
  height: 141px;
}

.gallery-page .monthly-gallery-item img {
  display: block;
  width: 129px;
  height: 141px;
  max-width: none;
  border: 0;
}

/* スマホのみ縮小 */
@media screen and (max-width: 480px) {
  .gallery-page .gallery-inner {
    width: 100%;
    max-width: calc(100% - 20px);
  }

  .gallery-page .monthly-gallery {
    width: 100%;
  }

  .gallery-page .monthly-gallery-grid {
    grid-template-columns: repeat(3, 1fr);
    column-gap: 8px;
    row-gap: 12px;
  }

  .gallery-page .monthly-gallery-item,
  .gallery-page .monthly-gallery-item a {
    width: 100%;
    height: auto;
  }

  .gallery-page .monthly-gallery-item img {
    width: 100%;
    height: auto;
    max-width: 129px;
    margin: 0 auto;
  }
}
/* =========================================================
   ダウンロードページ：背景をクリーム色に統一・罫線なし
========================================================= */

.download-page,
.download-page table,
.download-page tbody,
.download-page tr,
.download-page td,
.download-page th,
.download-page div,
.download-page p {
  background: #fcf9df !important;   /* ページのクリーム系背景色 */
  background-color: #fcf9df !important;
  border: none !important;
  box-shadow: none !important;
}

/* HTML内の bgcolor 指定を強制上書き */
.download-page td[bgcolor],
.download-page th[bgcolor] {
  background: #fcf9df !important;
  background-color: #fcf9df !important;
}

/* テーブルの罫線間の隙間もなくす */
.download-page table {
  border-collapse: collapse !important;
  border-spacing: 0 !important;
}

/* 画像リンクの枠線も消す */
.download-page img,
.download-page a img {
  border: 0 !important;
}

/* 必要なら少し余白を整える */
.download-page td {
  padding: 12px !important;
}



.download-page table[width="800"] > tbody > tr {
  vertical-align: top !important;
}

.download-page table[width="800"] > tbody > tr > td {
  vertical-align: top !important;
}

.download-page table[width="800"] > tbody > tr > td:first-child,
.download-page table[width="800"] > tbody > tr > td:nth-child(2) {
  padding-top: 0 !important;
  margin-top: 0 !important;
}

/* =========================================================
   SWF 表示エリア
========================================================= */

.swf-wrap {
  width: 100%;
  max-width: 900px;
  margin: 0 auto;
  text-align: center;
}

#container1 {
  width: 260px;
  height: 240px;
  max-width: 100%;
  margin: 0 auto;
  overflow: hidden;
}

a img {
  transition: filter 0.25s ease, transform 0.25s ease;
}

a:hover img {
  opacity: 1 !important;
  filter: brightness(1.12) contrast(1.03) !important;
}

/* PC・スマホ共通：最上部の赤帯をオレンジに変更 */
#header_message {
  background-color: #ec6700 !important;
}

/* =========================================================
   おたのしみコーナー：スマホ時だけ
   中央画像 → その下に左右GIFを2列表示
========================================================= */
@media screen and (max-width: 767px) {

  .enjoy_container {
    display: flex !important;
    flex-wrap: wrap !important;
    justify-content: center !important;
    align-items: flex-start !important;
    width: 100% !important;
    max-width: 320px !important;
    margin: 0 auto !important;
    gap: 14px 0 !important;
  }

  /* 中央の大きい画像を一番上に */
  .enjoy_column_center {
    order: 1 !important;
    flex: 0 0 100% !important;
    width: 100% !important;
    text-align: center !important;
    margin: 0 auto 12px !important;
  }

  .enjoy_column_center img {
    max-width: 230px !important;
    height: auto !important;
  }

  /* 左右のGIF列を中央画像の下へ */
  .enjoy_column:not(.enjoy_column_center) {
    order: 2 !important;
    flex: 0 0 50% !important;
    width: 50% !important;
    box-sizing: border-box !important;
    text-align: center !important;
    margin: 0 !important;
    padding: 0 6px !important;
  }

  .enjoy_column:not(.enjoy_column_center) a {
    display: block !important;
    margin: 0 auto 12px !important;
    text-align: center !important;
  }

  .enjoy_column:not(.enjoy_column_center) img {
    max-width: 100% !important;
    height: auto !important;
    display: inline-block !important;
  }

  .before-image,
  .after-image {
    margin: 0 !important;
    padding: 0 !important;
  }
}

/* =========================================================
   スマホ：ごろくとブログを6アイコンの下中央へ
========================================================= */
@media screen and (max-width: 767px) {

  /* 中央列＝ごろくとブログの列 */
  .enjoy_column_center {
    /*order: 3 !important;*/
    flex: 0 0 100% !important;
    width: 100% !important;
    text-align: center !important;
    margin: 18px auto 22px !important;
  }

  .enjoy_column_center a,
  .enjoy_column_center img {
    display: inline-block !important;
    margin-left: auto !important;
    margin-right: auto !important;
  }

  .enjoy_column_center img {
    max-width: 120px !important;
    height: auto !important;
  }

  /* 左右6アイコンは先に表示 */
  .enjoy_column:not(.enjoy_column_center) {
    order: 2 !important;
  }
}

/* =========================================================
   トップ記事スライダー：画像中央・商品名小さく・上下詰め
   ※Swiperのwidthは触らない
========================================================= */

#post_slider_swiper {
  overflow: hidden !important;
}

/* 各ブロック背景を白 */
#post_slider_swiper .post_item,
#post_slider_swiper .post_item > a,
#post_slider_swiper .image_wrap,
#post_slider_swiper .post_slider_contents {
  background: #ffffff !important;
  box-sizing: border-box !important;
}

/* 画像エリア：各ブロックの中央に配置 */
#post_slider_swiper .image_wrap {
  height: 300px !important;
  padding: 6px 8px 2px !important;
  margin: 0 !important;
  overflow: hidden !important;

  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
}

/* 画像：少し大きく、枠内中央 */
#post_slider_swiper .image_wrap img {
  display: block !important;
  width: auto !important;
  height: auto !important;
  max-width: 96% !important;
  max-height: 96% !important;
  object-fit: contain !important;
  object-position: center center !important;
  margin: auto !important;
}

/* 画像下?新商品の間を詰める */
#post_slider_swiper .post_slider_contents {
  padding: 3px 18px 8px !important;
  min-height: 54px !important;
  margin: 0 !important;
  border-top: none !important;
}

/* 新商品 */
#post_slider_swiper .post_slider_contents .category,
#post_slider_swiper .post_slider_contents .label,
#post_slider_swiper .category {
  font-size: 9px !important;
  line-height: 1.15 !important;
  margin: 0 0 2px !important;
  padding: 0 !important;
  font-weight: normal !important;
}

/*記事スライダー*/
.no_header_news {
  height: 350px !important;
}

#header_post_slider .image_wrap {
  width: 100%;
  height: 350px;
  overflow: hidden;
  position: relative;
  background-color: #ffffff;
}

/*丸ボタンのサイズ*/
.post_slider_pagination span {
  width: 10px;
  height: 10px;
}
/*画像を丸ボタンの間*/
.post_slider_pagination {
  position: relative !important;
  margin-top: 15px;
  bottom: 0 !important;
}

.p-slider-contents__title {
  font-size: 14px;
  color: #660000;
  line-height: 1;
  margin: -0.4em 0;
  overflow: hidden;
  transition: opacity 0.2s;
	font-weight: normal !important;
}

.post_slider_cotents {
  padding: 0 10px 20px 20px;
  border: 1px solid rgba(0, 0, 0, 0.2);
  border-top: none;
  height: 50px;
}

/* 商品名：おつまみセット等を小さく */
#post_slider_swiper .post_slider_contents .title,
#post_slider_swiper .post_slider_contents h3,
#post_slider_swiper .title {
  font-size: 8px !important;
  line-height: 1.2 !important;
  margin: 0 !important;
  padding: 0 !important;
  font-weight: normal !important;
  letter-spacing: 0.03em !important;
}

/* スマホ */
@media screen and (max-width: 799px) {

  #post_slider_swiper .image_wrap {
    height: 160px !important;/*画像の大きさ*/
    padding: 5px 5px 1px !important;
  }

  #post_slider_swiper .post_slider_contents {
    padding: 2px 7px 6px !important;
    min-height: 42px !important;
  }

  #post_slider_swiper .post_slider_contents .category,
  #post_slider_swiper .post_slider_contents .label,
  #post_slider_swiper .category {
    font-size: 7px !important;
    margin-bottom: 1px !important;
  }

  #post_slider_swiper .post_slider_contents .title,
  #post_slider_swiper .post_slider_contents h3,
  #post_slider_swiper .title {
    font-size: 7px !important;
    line-height: 1.18 !important;
  }
}

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

  #header_post_slider .p-slider-contents__title,
  #header_post_slider .p-slider-contents__title a,
  #header_post_slider .p-slider-contents__title span,
  #post_slider_swiper .p-slider-contents__title,
  #post_slider_swiper .p-slider-contents__title a,
  #post_slider_swiper .p-slider-contents__title span {
    font-size: 12px !important;
    line-height: 1.15 !important;
    margin: 0 !important;
    padding: 0 !important;
  }

  #header_post_slider .p-slider-contents__category,
  #header_post_slider .p-slider-contents__category span,
  #post_slider_swiper .p-slider-contents__category,
  #post_slider_swiper .p-slider-contents__category span {
    font-size: 10px !important;
    line-height: 1.1 !important;
    margin-bottom: 1px !important;
  }
	
	  .post_slider_pagination span,
  #header_slider_pagination span {
    width: 6px !important;
    height: 6px !important;
    margin: 0 3px !important;
  }
	  .post_slider_pagination,
  #header_slider_pagination {
    margin-top: 8px !important;
  }
}

/* =========================================================
   ぷっしゅんシリーズ発売スケジュール：iframe高さ調整
========================================================= */

.pussyun-schedule-iframe {
  display: block;
  width: 539px;
  max-width: 100%;
  height: 210px;
  margin: 0 auto;
  border: none;
}

/* スマホ */
@media screen and (max-width: 799px) {
  .pussyun-schedule-iframe {
    height: 140px !important;
  }
}

/* =========================================================
   スマホ：本文テキストを茶色で読みやすくする
========================================================= */
@media screen and (max-width: 799px) {

  .post_content p,
  .content_inner p,
  #index_tab_post_list .content_inner p {
    color: #5a3318 !important;
    font-size: 12px !important;
    line-height: 1.7 !important;
    letter-spacing: 0.03em !important;
    font-weight: 500 !important;
  }

  .post_content p a,
  .content_inner p a,
  #index_tab_post_list .content_inner p a {
    color: #8a2f18 !important;
    text-decoration: underline !important;
  }
}
/* =========================================================
   スマホ：SNSアイコン分、スライダー全体を下げる
   UTF-8
========================================================= */
@media screen and (max-width: 767px) {

  #header_slider_container {
    padding-top: 34px !important; /* SNS分だけ下げる */
    box-sizing: border-box !important;
  }

  #header_slider_container #post_slider,
  #header_slider_container .post_slide_wrap,
  #header_slider_container .post_slider_wrap,
  #header_slider_container .swiper-wrapper {
    margin-top: 0 !important;
  }

}

/* =========================================================
   スマホ：ロゴ下SNSボタン
   右寄せ＋スライダーとの間隔を確保
========================================================= */

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

  .top-sns-buttons {
    width: 100% !important;
    box-sizing: border-box !important;

    display: flex !important;
    justify-content: flex-end !important;
    align-items: center !important;
    gap: 8px !important;

    padding: 6px 18px 12px 0 !important;
    margin: 0 !important;

    background: #fcf9df !important;
    clear: both !important;
    position: relative !important;
    z-index: 5 !important;
  }

  .top-sns-buttons a {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    text-decoration: none !important;
  }

  .top-sns-buttons img {
    display: block !important;
    width: 26px !important;
    height: auto !important;
    border: 0 !important;
  }

  /* スライダーを下げる */
  #header_slider_container {
    margin-top: 0 !important;
    clear: both !important;
  }
}

/* PCでは非表示 */
@media screen and (min-width: 768px) {
  .top-sns-buttons {
    display: none !important;
  }
}

/* =========================================================
   スマホ：黒丸ページネーションを非表示
   スライダー下?タブボタン上の余白を詰める
========================================================= */
@media screen and (max-width: 767px) {

  /* スライダー下の黒丸を非表示 */
  #header_slider_pagination,
  .post_slider_pagination {
    display: none !important;
    height: 0 !important;
    margin: 0 !important;
    padding: 0 !important;
  }

  /* スライダー下の余白を詰める */
  #header_slider_container {
    margin-bottom: 0 !important;
    padding-bottom: 0 !important;
  }

  #header_post_slider,
  #post_slider_swiper {
    margin-bottom: 0 !important;
    padding-bottom: 0 !important;
  }

  /* オレンジ背景部分の上下余白を詰める */
  .top_main_inner {
    padding-top: 4px !important;
    padding-bottom: 8px !important;
    margin-top: 5px !important;
    margin-bottom: 0 !important;
  }

  #main_content,
  #index_tab_post_list {
    padding-top: 0 !important;
    margin-top: 0 !important;
  }

  /* タブボタン全体 */
  #index_tab {
    margin-top: 0 !important;
    margin-bottom: 8px !important;
    padding-top: 0 !important;
    padding-bottom: 0 !important;
  }

  /* タブボタン1個ごと */
  #index_tab a {
    min-height: 28px !important;
    height: 28px !important;
    line-height: 28px !important;
    margin-bottom: 6px !important;
    padding-top: 0 !important;
    padding-bottom: 0 !important;
  }
}
/* =========================================================
   スマホ：タブ横一列＋下コンテンツブロック密着
   タブ切り替えJSを壊さない版
   UTF-8
========================================================= */
@media screen and (max-width: 799px) {

  /* タブ＋下コンテンツ全体 */
  #index_tab_post_list {
    width: 92% !important;
    margin: 10px auto 18px !important; /* タブ上は少し空ける */
    padding: 0 !important;
    background: transparent !important;
    border: none !important;
    box-sizing: border-box !important;
  }

  /* タブ全体 */
  #index_tab {
    width: 100% !important;
    height: auto !important;
    margin: 0 !important;
    padding: 0 !important;
    border: none !important;
    box-sizing: border-box !important;
  }

  #index_tab ol {
    display: flex !important;
    width: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
    list-style: none !important;
  }

  #index_tab li {
    width: 25% !important;
    margin: 0 !important;
    padding: 0 !important;
    float: none !important;
    box-sizing: border-box !important;
  }

  /* 通常タブ */
  #index_tab li a,
  #index_tab li .rich_font_main_content {
    display: flex !important;
    width: 100% !important;
    height: 28px !important;
    min-height: 28px !important;

    align-items: center !important;
    justify-content: center !important;

    margin: 0 !important;
    padding: 3px 2px !important;
    box-sizing: border-box !important;

    font-size: 9px !important;
    line-height: 1.2 !important;
    text-align: center !important;
    white-space: nowrap !important;

    background: #f8f3e6 !important;
    color: #5a3318 !important;

    border: 1px solid #d8c8a8 !important;
    border-bottom: 1px solid #d8c8a8 !important;
    border-radius: 6px 6px 0 0 !important;

    text-decoration: none !important;
  }

  /* 隣り合うタブの線を重ねる */
  #index_tab li + li a,
  #index_tab li + li .rich_font_main_content {
    margin-left: -1px !important;
  }

  /* 選択中タブ */
  #index_tab li.active a,
  #index_tab li.active .rich_font_main_content {
    background: #ffffff !important;
    color: #7a4a00 !important;
    border-bottom: 1px solid #ffffff !important;
    font-weight: bold !important;
    position: relative !important;
    z-index: 5 !important;
  }

  /* 下のコンテンツブロック
     displayは指定しない：JSのタブ切替を壊さない */
  #index_tab_post_list .tab_post_list,
  #index_tab_post_list .ajax_post_list_wrap {
    width: 100% !important;
    box-sizing: border-box !important;

    margin: -1px 0 0 !important; /* タブと密着 */
    padding: 12px 10px 14px !important;

    background: #ffffff !important;
    border: 1px solid #d8c8a8 !important;
    border-radius: 0 0 6px 6px !important;
  }

  /* 中身の上余白を消す */
  #index_tab_post_list .tab_post_list > *:first-child,
  #index_tab_post_list .ajax_post_list_wrap > *:first-child {
    margin-top: 0 !important;
  }

  #index_tab_post_list img {
    max-width: 100% !important;
    height: auto !important;
  }
}
/* =========================================================
   スマホ：タブ下コンテンツ内の緑余白を完全に削除
   UTF-8
========================================================= */
@media screen and (max-width: 799px) {

  /* タブコンテンツ内の外側余白 */
  #index_tab_post_list .tab_post_list.ajax_post_list_wrap,
  #index_tab_post_list .post_list,
  #index_tab_post_list .ajax_post_list {
    margin-top: 0 !important;
    padding-top: 0 !important;
  }

  /* 緑で表示されている item / content / content_inner の余白を削除 */
  #index_tab_post_list .tab_post_list.ajax_post_list_wrap .item,
  #index_tab_post_list .tab_post_list.ajax_post_list_wrap .item.animate,
  #index_tab_post_list .tab_post_list.ajax_post_list_wrap .content
  {
    margin: 0 !important;
    padding: 0 !important;
    border: none !important;
  }
	#index_tab_post_list .tab_post_list.ajax_post_list_wrap .content_inner{
	margin-top: 20px !important;
    padding: 0 !important;
    border: none !important;
	}
  /* 中身の最初の要素の余白も削除 */
  #index_tab_post_list .tab_post_list.ajax_post_list_wrap .content_inner > *:first-child {
    margin-top: 0 !important;
    padding-top: 0 !important;
  }

  /* 画像・表・本文が余計な空きを持たないようにする */
  #index_tab_post_list .tab_post_list.ajax_post_list_wrap img,
  #index_tab_post_list .tab_post_list.ajax_post_list_wrap table,
  #index_tab_post_list .tab_post_list.ajax_post_list_wrap p {
    margin-top: 0 !important;
  }
}

/* =========================================================
   バナー画像同士の余白調整
   PC：30px / スマホ：20px
   ※テキストpには line-height:0 をかけない
   UTF-8
========================================================= */

/* 画像を包んでいるpだけ対象 */
#single_banner_top p.before-image,
#single_banner_top p.after-image,
#single_banner_top p.before-image.after-image {
  margin-top: 0 !important;
  margin-bottom: 30px !important; /* PC：画像と画像の間隔 */
  padding: 0 !important;
  line-height: 0 !important;
}

/* 画像リンク */
#single_banner_top p.before-image a,
#single_banner_top p.after-image a,
#single_banner_top p.before-image.after-image a {
  display: block !important;
  margin: 0 !important;
  padding: 0 !important;
  line-height: 0 !important;
}

/* 画像 */
#single_banner_top p.before-image img,
#single_banner_top p.after-image img,
#single_banner_top p.before-image.after-image img {
  display: block !important;
  width: 100% !important;
  max-width: 100% !important;
  height: auto !important;
  margin: 0 !important;
  padding: 0 !important;
}

/* テキストpは読みやすく戻す */
#single_banner_top p:not(.before-image):not(.after-image) {
  margin: 0 0 18px !important;
  padding: 0 !important;
  color: #5a3318 !important;
  font-size: 14px !important;
  line-height: 1.8 !important;
  letter-spacing: 0.04em !important;
  font-weight: 500 !important;
}

/* テキスト内リンク */
#single_banner_top p:not(.before-image):not(.after-image) a {
  display: inline !important;
  color: #8a2f18 !important;
  line-height: inherit !important;
  text-decoration: underline !important;
}

/* スマホのみ：画像と画像の間隔を20pxにする */
@media screen and (max-width: 767px) {
  #single_banner_top p.before-image,
  #single_banner_top p.after-image,
  #single_banner_top p.before-image.after-image {
    margin-bottom: 20px !important;
  }

  #single_banner_top p:not(.before-image):not(.after-image) {
    font-size: 13px !important;
    line-height: 1.75 !important;
  }
}

/* =========================================================
   スマホ：上部スライダーの左右に余白を作る
   UTF-8
========================================================= */
@media screen and (max-width: 767px) {

  /* スライダー全体を下のコンテンツ幅に合わせる */
  #header_post_slider {
    width: calc(100% - 28px) !important;
    margin: 0 auto 12px !important;
    padding: 0 !important;
    box-sizing: border-box !important;
    overflow: hidden !important;
  }

  /* Swiper本体も親幅に合わせる */
  #header_post_slider .post_slide_swiper,
  #header_post_slider .swiper {
    width: 100% !important;
    overflow: hidden !important;
  }

  /* 横にはみ出さないように調整 */
  #header_post_slider .swiper-wrapper {
    width: 100% !important;
    box-sizing: border-box !important;
  }

  /* 2列表示の幅を親内に収める */
  #header_post_slider .post_item,
  #header_post_slider .swiper-slide {
    width: 50% !important;
    box-sizing: border-box !important;
  }

  /* 画像もカード内に収める */
  #header_post_slider img {
    width: 100% !important;
    height: auto !important;
    display: block !important;
  }
}

/* =========================================================
   PC：4つのタブボタンと下コンテンツを一体化
   UTF-8
========================================================= */
@media screen and (min-width: 768px) {

  /* タブ＋コンテンツ全体 */
  #index_tab_post_list {
    width: 100% !important;
    max-width: 720px !important;
    margin: 0 0 24px 0 !important;
    padding: 0 !important;
    background: transparent !important;
    border: none !important;
    box-sizing: border-box !important;
  }

  /* タブ全体 */
  #index_tab {
    display: flex !important;
    width: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
    list-style: none !important;
    border: none !important;
    gap: 0 !important;
  }

  /* タブ1個ずつ */
  #index_tab li {
    width: 25% !important;
    margin: 0 !important;
    padding: 0 !important;
    list-style: none !important;
    box-sizing: border-box !important;
  }

  /* タブボタン */
  #index_tab li a {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;

    height: 38px !important;
    padding: 0 8px !important;
    margin: 0 !important;

    background: #fffdf3 !important;
    border: 1px solid #e2d8b8 !important;
    border-bottom: none !important;

    color: #6b4a1f !important;
    font-size: 13px !important;
    line-height: 1.3 !important;
    text-align: center !important;
    text-decoration: none !important;
    box-sizing: border-box !important;

    border-radius: 5px 5px 0 0 !important;
  }

  /* タブ同士の線を重ねる */
  #index_tab li + li a {
    margin-left: -1px !important;
  }

  /* 選択中タブ */
  #index_tab li.active a,
  #index_tab li.current a,
  #index_tab li a.active,
  #index_tab li a.current {
    background: #ffffff !important;
    color: #c85a00 !important;
    font-weight: bold !important;
    position: relative !important;
    z-index: 2 !important;
  }

  /* 下のコンテンツ枠 */
  #index_tab_post_list .tab_post_list,
  #index_tab_post_list .ajax_post_list_wrap,
  #index_tab_post_list .post_list,
  #index_tab_post_list .post_list_type_2,
  #index_tab_post_list .tab_content,
  #index_tab_post_list .tabContents,
  #index_tab_post_list > div:not(#index_tab) {
    width: 100% !important;
    margin: 0 !important;
    padding: 14px 16px 16px !important;
    background: #ffffff !important;
    border: 1px solid #e2d8b8 !important;
    box-sizing: border-box !important;
    border-radius: 0 0 5px 5px !important;
  }

  /* タブ直下の余白を消す */
  #index_tab + div,
  #index_tab + ul,
  #index_tab + section {
    margin-top: 0 !important;
  }

  /* コンテンツ内の余白を詰める */
  #index_tab_post_list p,
  #index_tab_post_list ul,
  #index_tab_post_list dl {
    margin-top: 0 !important;
  }
}
/* =========================================================
   PCのみ：タブと下コンテンツをスマホ版と同じ見た目にする
   スマホCSSには影響させない
   UTF-8
========================================================= */
@media screen and (min-width: 768px) {

  /* タブ＋下コンテンツ全体 */
  #index_tab_post_list {
    width: 100% !important;
    max-width: 810px !important;
    margin: 0 0 24px 0 !important;
    padding: 0 !important;
    background: transparent !important;
    border: none !important;
    box-shadow: none !important;
    box-sizing: border-box !important;
  }

  /* タブ全体 */
  #index_tab {
    width: 100% !important;
    height: auto !important;
    margin: 0 !important;
    padding: 0 !important;
    border: none !important;
    box-sizing: border-box !important;
  }

  #index_tab ol {
    display: flex !important;
    width: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
    list-style: none !important;
  }

  /* タブ1個ずつ */
  #index_tab li {
    width: 25% !important;
    margin: 0 !important;
    padding: 0 !important;
    float: none !important;
    list-style: none !important;
    box-sizing: border-box !important;
  }

  /* タブボタン：スマホと同じベージュ系 */
  #index_tab li a,
  #index_tab li .rich_font_main_content {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;

    width: 100% !important;
    height: 38px !important;
    min-height: 38px !important;

    margin: 0 !important;
    padding: 4px 8px !important;
    box-sizing: border-box !important;

    background: #f8f3e6 !important;
    color: #5a3318 !important;

    border: 1px solid #d8c8a8 !important;
    border-bottom: 1px solid #d8c8a8 !important;
    border-radius: 6px 6px 0 0 !important;

    font-size: 14px !important;
    font-weight: bold !important;
    line-height: 1.3 !important;
    text-align: center !important;
    white-space: nowrap !important;
    text-decoration: none !important;

    box-shadow: none !important;
  }

  /* タブの区切り線を残しつつ二重線を防ぐ */
  #index_tab li + li a,
  #index_tab li + li .rich_font_main_content {
    margin-left: -1px !important;
  }

  /* 選択中タブ：白にして下コンテンツとつなげる */
  #index_tab li.active a,
  #index_tab li.active .rich_font_main_content,
  #index_tab li.current a,
  #index_tab li.current .rich_font_main_content,
  #index_tab li a.active,
  #index_tab li a.current {
    background: #ffffff !important;
    color: #7a4a00 !important;
    border-bottom: 1px solid #ffffff !important;
    font-weight: bold !important;
    position: relative !important;
    z-index: 5 !important;
  }

  /* 下のコンテンツ：タブに密着 */
  #index_tab_post_list .tab_post_list,
  #index_tab_post_list .ajax_post_list_wrap {
    width: 100% !important;
    box-sizing: border-box !important;

    margin: -1px 0 0 !important;
    padding: 16px 18px 18px !important;

    background: #ffffff !important;
    border: 1px solid #d8c8a8 !important;
    border-radius: 0 0 6px 6px !important;
    box-shadow: none !important;
  }

  /* コンテンツ内の余計な外枠・余白を削除 */
  #index_tab_post_list .post_list,
  #index_tab_post_list .post_list_type_2,
  #index_tab_post_list .item,
  #index_tab_post_list .content,
  #index_tab_post_list .content_inner {
    margin: 0 !important;
    padding: 0 !important;
    border: none !important;
    box-shadow: none !important;
    background: transparent !important;
  }

  /* iframeまわり */
  #index_tab_post_list iframe {
    display: block !important;
    max-width: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
    border: none !important;
    box-shadow: none !important;
  }

  /* pタグ由来の余白を削除 */
  #index_tab_post_list p {
    margin: 0 !important;
    padding: 0 !important;
  }

  /* 画像・表のはみ出し防止 */
  #index_tab_post_list img,
  #index_tab_post_list table {
    max-width: 100% !important;
  }
}
/* =========================================================
   PCのみ：タブ下コンテンツを少しゆったり・文字を読みやすく
   スマホCSSには影響させない
   UTF-8
========================================================= */
@media screen and (min-width: 768px) {

  /* 下のコンテンツ：余白を広げる */
  #index_tab_post_list .tab_post_list,
  #index_tab_post_list .ajax_post_list_wrap {
    padding: 20px 22px 22px !important;
    min-height: 106px !important;
  }

  /* コンテンツ本文 */
  #index_tab_post_list .content_inner,
  #index_tab_post_list .content_inner p,
  #index_tab_post_list .tab_post_list p,
  #index_tab_post_list .ajax_post_list_wrap p {
    color: #5a3318 !important;
    font-size: 15px !important;
    line-height: 1.75 !important;
    letter-spacing: 0.08em !important;
    font-weight: 500 !important;
  }

  /* メルマガ説明文などが詰まらないように */
  #index_tab_post_list .content_inner p {
    margin: 0 0 8px !important;
    padding: 0 !important;
  }

  /* 最後の段落だけ下余白なし */
  #index_tab_post_list .content_inner p:last-child {
    margin-bottom: 0 !important;
  }

  /* iframe内ではなく、通常テキスト表示の時の余白調整 */
  #index_tab_post_list .item {
    padding: 0 !important;
  }

  /* タブ文字も少し読みやすく */
  #index_tab li a,
  #index_tab li .rich_font_main_content {
    height: 40px !important;
    min-height: 40px !important;
    font-size: 14px !important;
    letter-spacing: 0.04em !important;
  }
}

/* =========================================================
   みなさまの声ページ：フォーム右はみ出し防止・安全版
   UTF-8
========================================================= */


/* フォーム本体 */
.entry-content form {
  width: 100% !important;
  max-width: 100% !important;
  box-sizing: border-box !important;
  overflow: visible !important;
}

/* tableフォームの横幅を画面内に収める */
.entry-content form table {
  width: 100% !important;
  max-width: 100% !important;
  box-sizing: border-box !important;
}

/* セルの中身が横に押し出さないようにする */
.entry-content form th,
.entry-content form td {
  box-sizing: border-box !important;
  word-break: break-word !important;
  overflow-wrap: break-word !important;
}

/* 入力欄だけ横幅を調整 */
.entry-content form input[type="text"],
.entry-content form input[type="email"],
.entry-content form input[type="tel"],
.entry-content form textarea,
.entry-content form select {
  width: 100% !important;
  max-width: 100% !important;
  box-sizing: border-box !important;
}

/* textarea の固定幅対策 */
.entry-content form textarea {
  min-width: 0 !important;
  resize: vertical !important;
}


/* =========================================================
   スマホ時：フォームを縦積みにして右はみ出し防止
========================================================= */
@media screen and (max-width: 767px) {

  .entry-content form table,
  .entry-content form tbody,
  .entry-content form tr,
  .entry-content form th,
  .entry-content form td {
    display: block !important;
    width: 100% !important;
    max-width: 100% !important;
    box-sizing: border-box !important;
  }

  .entry-content form th,
  .entry-content form td {
    padding-left: 8px !important;
    padding-right: 8px !important;
  }

  .entry-content form th {
    padding-bottom: 4px !important;
  }

  .entry-content form td {
    padding-top: 4px !important;
    padding-bottom: 12px !important;
  }
}

/* =========================================================
   ヘッダー上部：キャッチコピー中央・SNS右寄せ
   class未反映でも効く版
   UTF-8
========================================================= */

.p-header-site_catch {
  width: 100% !important;
  box-sizing: border-box !important;
}

/* site_catch全体 */
.p-header-site_catch p#site_catch {
  display: grid !important;
  grid-template-columns: 1fr auto 1fr !important;
  align-items: center !important;

  width: 100% !important;
  max-width: 880px !important;
  min-height: 50px !important;

  margin: 0 auto !important;
  padding: 0 !important;
  box-sizing: border-box !important;

  line-height: 1.4 !important;
  text-align: center !important;
}

/* 1つ目のspan＝キャッチコピー */
.p-header-site_catch p#site_catch > span:first-child,
.p-header-site_catch p#site_catch > .site_catch_text {
  grid-column: 2 !important;

  display: block !important;
  text-align: center !important;
  white-space: nowrap !important;

  margin: 0 !important;
  padding: 0 !important;
  line-height: 50px !important;
  min-height: 50px !important;
}

/* 2つ目のspan＝SNSアイコン */
.p-header-site_catch p#site_catch > span:nth-child(2),
.p-header-site_catch p#site_catch > .site_catch_sns {
  grid-column: 3 !important;
  justify-self: end !important;

  display: flex !important;
  align-items: center !important;
  justify-content: flex-end !important;
  gap: 10px !important;

  margin: 0 !important;
  padding: 0 !important;
  line-height: 0 !important;
  text-align: right !important;
}

/* SNSリンク */
.p-header-site_catch p#site_catch > span:nth-child(2) a,
.p-header-site_catch p#site_catch > .site_catch_sns a {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;

  margin: 0 !important;
  padding: 0 !important;
  line-height: 0 !important;
  text-decoration: none !important;
}

/* SNS画像 */
.p-header-site_catch p#site_catch img {
  display: block !important;
  margin: 0 !important;
  padding: 0 !important;
  height: auto !important;
  border: none !important;
  vertical-align: middle !important;
}

/* ルナぽん */
.p-header-site_catch p#site_catch .luna_pon_icon,
.p-header-site_catch p#site_catch a[href="/luna-pon/"] img {
  width: 45px !important;
  height: auto !important;
}

/* =========================================================
   スマホ：スライダーとタブの間隔を詰める
   UTF-8
========================================================= */
@media screen and (max-width: 600px) {

  /* スライダー全体の下余白を削る */
  #header_slider_container,
  #header_slider_container .swiper,
  #header_slider_container .swiper-wrapper,
  #header_slider_container .swiper-slide {
    margin-bottom: 0 !important;
    padding-bottom: 0 !important;
  }

  /* スライダー下のページネーション余白を削る */
  #header_slider_pagination {
    margin: 0 !important;
    padding: 0 !important;
    height: 0 !important;
    line-height: 0 !important;
  }

  /* メインコンテンツ上の余白を削る */
  #main_content,
  #main_col {
    margin-top: 0 !important;
    padding-top: 0 !important;
  }

  /* タブ全体の上余白を詰める */
  #index_tab_post_list {
    margin-top: 0 !important;
    padding-top: 0 !important;
  }

  /* タブ本体の余白も調整 */
  #index_tab {
    margin-top: 0 !important;
    padding-top: 0 !important;
  }
}
/* =========================================================
   スマホ：SNSボタンを上に上げてヘッダーを低くする
   UTF-8
========================================================= */
@media screen and (max-width: 767px) {

  /* SNSボタンの塊を上に移動 */
  .top-sns-buttons.mobile-only {
    position: relative !important;
    top: -8px !important;

    margin-top: 0 !important;
    margin-bottom: 4px !important;
    padding-top: 0 !important;
    padding-bottom: 10px !important;

    display: flex !important;
    justify-content: flex-end !important;
    align-items: center !important;
    gap: 6px !important;
  }

  /* SNS画像サイズは現在のまま維持 */
  .top-sns-buttons.mobile-only img {
    width: 26px !important;
    height: auto !important;
    display: block !important;
    margin: 0 !important;
    padding: 0 !important;
  }

  /* SNSリンクの余白を削除 */
  .top-sns-buttons.mobile-only a {
    display: block !important;
    line-height: 0 !important;
    margin: 0 !important;
    padding: 0 !important;
  }

  /* ヘッダー下の余白を削る */
  #header,
  #header_top {
    padding-bottom: 0 !important;
    margin-bottom: 0 !important;
  }
}
