@charset "UTF-8";
/* =========================================================================
   【Land-A仕様】絶対カラーパレット・変数定義（規律の根源）
   ========================================================================= */
:root {
  --landa-color-main: #a83f3f; /* テーマカラー（えんじ） */
  --landa-color-text: #333333; /* 基本テキスト */
  --landa-color-title: #191919; /* タイトル・強調テキスト */
  --landa-border-light: #e0e0e0; /* 基本の薄い枠線 */
  --landa-border-base: #d0d0d0; /* アクセント枠線（公式グレー） */
  --landa-bg-gray: #f2f2f2; /* 基本のグレー背景 */
}

/* テキスト色・背景色パレット */
.has-cyan-bluish-gray-color {
  color: #666 !important;
}

.has-pink-background-color {
  background-color: #F9C1CF;
}

.has-yellow-background-color {
  background-color: #FFEC50;
}

.has-pale-cyan-blue-background-color {
  background-color: #c1e1dc;
}

.has-light-gray-background-color {
  background-color: #eeeeee;
}

.has-light-green-cyan-background-color {
  background-color: #A2D29E;
}

.has-red-background-color {
  background-color: #cf2e2e;
}

.has-orange-background-color {
  background-color: #eb8a44;
}

.has-amber-background-color {
  background-color: #fcb900;
}

.has-vivid-green-cyan-background-color {
  background-color: #00d084;
}

.has-vivid-cyan-blue-background-color {
  background-color: #0693e3;
}

.has-white-background-color {
  background-color: #ffffff;
}

.has-dark-gray-background-color {
  background-color: #313131;
}

/* =========================================================
   【Land-A仕様】Contact Form 7（新規会員登録 申請フォーム）
========================================================= */
.wpcf7 {
  margin-top: 20px;
  max-width: 600px;
}

.wpcf7 form p {
  margin-bottom: 24px;
}

.wpcf7 form label {
  display: block;
  font-weight: bold;
  font-size: 1.4rem;
  color: var(--landa-color-text);
  margin-bottom: 8px;
  line-height: 1.5;
}

.wpcf7 form label span[style*=font-size] {
  display: block;
  font-size: 1.2rem !important;
  color: #555555 !important;
  margin-top: 4px;
  margin-bottom: 8px;
}

.wpcf7 form input[type=text], .wpcf7 form input[type=email] {
  width: 100%;
  padding: 12px 15px;
  font-size: 1.6rem;
  color: var(--landa-color-text);
  background-color: #ffffff;
  border: 1px solid var(--landa-border-base);
  border-radius: 4px;
  box-sizing: border-box;
  box-shadow: none !important;
  transition: border-color 0.2s ease, box-shadow 0.2s ease;
  -moz-appearance: none;
  appearance: none;
  -webkit-appearance: none;
}

.wpcf7 form input[type=text]:focus, .wpcf7 form input[type=email]:focus {
  outline: none;
  border-color: #285a26;
  box-shadow: 0 0 0 1px #285a26 !important;
  background-color: #ffffff;
}

.wpcf7 form .wpcf7-not-valid-tip {
  font-size: 1.3rem;
  color: #903e3a;
  font-weight: bold;
  margin-top: 6px;
  display: block;
}

.wpcf7 form .wpcf7-response-output {
  background-color: #fcfcfc !important;
  border-radius: 4px !important;
  box-shadow: none !important;
  color: var(--landa-color-text) !important;
  padding: 15px 20px !important;
  font-size: 1.4rem !important;
  margin-top: 24px !important;
  border: 1px solid var(--landa-border-light) !important;
  border-left: 4px solid var(--landa-border-light) !important;
}

.wpcf7 form.invalid .wpcf7-response-output, .wpcf7 form.unaccepted .wpcf7-response-output, .wpcf7 form.payment-required .wpcf7-response-output {
  border-left-color: #903e3a !important;
}

.wpcf7 form.sent .wpcf7-response-output {
  border-left-color: #285a26 !important;
}

/* =========================================================
   【Land-A仕様】マイページ（ダッシュボード）UI
========================================================= */
/* --- Sections --- */
.land-a-dashboard-section {
  margin-bottom: 35px;
  padding: 25px 30px;
  background-color: #fcfcfc;
  border: 1px solid var(--landa-border-light);
  border-left: 4px solid #285a26;
  border-radius: 4px;
  box-shadow: none;
}

.land-a-recommend-section {
  border-left-color: #285a26;
}

/* --- Labels & Texts --- */
.land-a-system-label {
  display: inline-block;
  margin-bottom: 16px;
  color: #285a26;
  font-family: monospace;
  font-size: 1.3rem;
  font-weight: bold;
  letter-spacing: 0.05em;
}

.land-a-no-record {
  margin: 0;
  color: #555555;
  font-size: 1.4rem;
}

/* --- Record List --- */
.content ul.land-a-record-list,
.land-a-record-list {
  margin: 0 !important;
  padding: 0 !important;
  background-color: transparent !important;
  list-style: none !important;
}

.content ul.land-a-record-list > li,
.land-a-record-list li {
  display: flex;
  align-items: flex-start;
  margin-bottom: 12px;
  padding-bottom: 12px;
  padding-left: 0 !important;
  border-bottom: 1px solid #eaeaea;
  line-height: 1.6;
}

.content ul.land-a-record-list > li::before {
  display: none !important;
  content: none !important;
}

.land-a-record-list li:last-child {
  margin-bottom: 0;
  padding-bottom: 0;
  border-bottom: none;
}

.land-a-record-icon {
  margin-right: 8px;
  font-size: 1.4rem;
  line-height: 1.6;
}

.land-a-record-prefix {
  margin-top: 3px;
  margin-right: 8px;
  color: #777777;
  font-family: monospace;
  font-size: 1.2rem;
  white-space: nowrap;
}

.land-a-record-list a {
  color: var(--landa-color-text);
  font-size: 1.5rem;
  font-weight: bold;
  text-decoration: none;
  transition: color 0.2s ease;
}

.land-a-record-list a:hover {
  color: #903e3a;
  text-decoration: underline;
}

/* --- Pagination --- */
.land-a-pagination {
  margin-top: 20px;
  text-align: center;
}

.land-a-pagination a,
.land-a-pagination span {
  display: inline-block;
  margin: 0 3px;
  padding: 6px 14px;
  background-color: #ffffff;
  border: 1px solid var(--landa-border-base);
  border-radius: 4px;
  color: var(--landa-color-text);
  font-size: 1.3rem;
  text-decoration: none;
  transition: all 0.2s ease;
}

.land-a-pagination a:hover {
  background-color: var(--landa-bg-gray);
}

.land-a-pagination .current {
  background-color: #285a26;
  border-color: #285a26;
  color: #ffffff;
  font-weight: bold;
}

/* --- Misc Utilities --- */
.dateList__item.icon-folder:has(.report-badge) {
  display: none !important;
}

/* =========================================================
   【Land-A仕様】ハンバーガーメニュー内（ウィジェットUI統治）
========================================================= */
/* --- Screen Reader (Accessibility) --- */
.screen-reader-text,
.menuBtn__contentInner .wp-block-search__label {
  position: absolute;
  width: 1px;
  height: 1px;
  margin: -1px;
  padding: 0;
  border: 0;
  overflow: hidden;
  clip: rect(1px, 1px, 1px, 1px);
  clip-path: inset(50%);
  word-wrap: normal;
}

/* --- Menu Base --- */
.menuBtn__navi {
  margin: 0 -15px 40px;
  padding: 20px 15px;
  background-color: #c1d1be;
}

.menuBtn__contentInner {
  margin-bottom: 0 !important;
  padding: 20px 15px;
  background-color: #ffffff;
}

.menuBtn__contentInner aside.widget_block {
  margin-bottom: 24px !important;
}

/* --- Status & Logout Buttons --- */
.menuBtn__contentInner .statusBtn__navi,
.menuBtn__contentInner .land-a-status-wrapper {
  margin-bottom: 24px;
}

.menuBtn__contentInner .statusBtn__link {
  display: block;
  position: relative;
  width: 100%;
  padding: 15px 20px;
  box-sizing: border-box;
  background-color: #ffffff;
  border: 1px solid var(--landa-border-light);
  border-left: 4px solid #285a26;
  border-radius: 4px;
  text-align: left;
  text-decoration: none;
  pointer-events: none;
}

.menuBtn__contentInner .logoutBtn__link {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  width: 100%;
  padding: 12px;
  box-sizing: border-box;
  background-color: var(--landa-bg-gray);
  border: 1px solid var(--landa-border-base);
  border-left: 4px solid var(--landa-border-base);
  border-radius: 4px;
  cursor: pointer;
  transition: background-color 0.2s ease, border-color 0.2s ease, transform 0.1s ease;
}

.menuBtn__contentInner .land-a-status-main {
  display: block;
  color: var(--landa-color-text);
  font-size: 1.5rem;
  font-weight: bold;
  line-height: 1.4;
}

.menuBtn__contentInner .logoutBtn__link .land-a-logout-main {
  color: #903e3a;
  font-size: 1.4rem;
  font-weight: bold;
}

.menuBtn__contentInner .land-a-status-sub,
.menuBtn__contentInner .land-a-logout-sub {
  display: block;
  margin-top: 4px;
  color: #555555;
  font-size: 1.2rem;
  line-height: 1.4;
}

@media (hover: hover) {
  .menuBtn__contentInner .logoutBtn__link:hover {
    background-color: #f9f9f9;
    border-color: var(--landa-border-base);
    border-left-color: #903e3a;
  }
}
.menuBtn__contentInner .logoutBtn__link:active {
  transform: scale(0.98);
}

/* --- Search Block --- */
.menuBtn__contentInner .wp-block-search__inside-wrapper {
  display: flex;
  width: 100%;
  background-color: #ffffff;
  border: 1px solid var(--landa-border-base);
  border-radius: 4px;
  overflow: hidden;
  transition: border-color 0.2s ease;
}

.menuBtn__contentInner .wp-block-search__inside-wrapper:focus-within {
  border-color: #285a26;
}

.menuBtn__contentInner .wp-block-search__input {
  width: 100%;
  padding: 12px 15px;
  background-color: transparent;
  border: none;
  color: var(--landa-color-text);
  font-size: 1.5rem;
  outline: none;
}

.menuBtn__contentInner .wp-block-search__button {
  padding: 0 20px;
  background-color: #4e5750;
  border: none;
  color: #ffffff;
  font-weight: bold;
  cursor: pointer;
  transition: background-color 0.2s ease;
}

@media (hover: hover) {
  .menuBtn__contentInner .wp-block-search__button:hover {
    background-color: #285a26;
  }
}
/* --- Accordion & Menu Box --- */
.menuBtn__contentInner .land-a-menu-box,
.menuBtn__contentInner dl.accordionBox {
  display: block !important;
  width: 100% !important;
  margin: 0 0 24px 0 !important;
  box-sizing: border-box !important;
  background-color: #ffffff;
  border: 1px solid var(--landa-border-light);
  border-radius: 4px;
  overflow: hidden;
}

.menuBtn__contentInner .land-a-menu-heading,
.menuBtn__contentInner dl.accordionBox dt.heading-widget {
  margin: 0;
  padding: 15px 20px;
  background-color: #fcfcfc;
  border-bottom: 1px solid var(--landa-border-light);
  color: var(--landa-color-title);
  font-size: 1.4rem;
  font-weight: bold;
  cursor: default;
}

.menuBtn__contentInner .land-a-menu-box dd,
.menuBtn__contentInner dl.accordionBox dd {
  margin: 0;
  padding: 0;
  background-color: #ffffff;
}

.menuBtn__contentInner .land-a-menu-box ul,
.menuBtn__contentInner dl.accordionBox ul {
  margin: 0;
  padding: 10px 0;
  list-style: none;
}

.menuBtn__contentInner .land-a-menu-box li,
.menuBtn__contentInner dl.accordionBox li {
  position: relative;
  margin: 0;
}

.menuBtn__contentInner .land-a-menu-box li a,
.menuBtn__contentInner dl.accordionBox li a {
  display: block;
  position: relative;
  padding: 12px 20px 12px 40px;
  color: #555555;
  font-size: 1.3rem;
  text-decoration: none;
  transition: background-color 0.2s, color 0.2s;
}

.menuBtn__contentInner .land-a-menu-box li a::before,
.menuBtn__contentInner dl.accordionBox li a::before {
  content: "";
  position: absolute;
  top: 0;
  left: 20px;
  width: 10px;
  height: 22px;
  border-bottom: 1px solid var(--landa-border-base);
  border-left: 1px solid var(--landa-border-base);
}

@media (hover: hover) {
  .menuBtn__contentInner .land-a-menu-box li a:hover,
  .menuBtn__contentInner dl.accordionBox li a:hover {
    background-color: var(--landa-bg-gray);
    color: var(--landa-color-main);
  }
}
.land-a-menu-box a .dashicons-external,
.wp-block-button__link .dashicons-external {
  margin-left: 4px;
  font-size: 1.3rem !important;
  font-weight: normal !important;
  vertical-align: -2px !important;
  opacity: 0.7;
}

/* =========================================================
   【Land-A仕様】ショートコード用ハンバーガーメニューボタン
========================================================= */
.menuBtn__contentInner .land-a-menu-btn-wrapper {
  width: 100%;
  margin-bottom: 24px;
}

.menuBtn__contentInner .menu_button_hamburger {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  width: 100%;
  padding: 15px 20px;
  box-sizing: border-box;
  background-color: #ffffff;
  border: 1px solid var(--landa-border-light);
  border-radius: 4px;
  color: var(--landa-color-text);
  font-size: 1.4rem;
  font-weight: bold;
  line-height: 1.5;
  text-decoration: none;
  transition: background-color 0.2s ease, color 0.2s ease, border-color 0.2s ease, transform 0.1s ease;
}

@media (hover: hover) {
  .menuBtn__contentInner .menu_button_hamburger:hover {
    background-color: #f9f9f9;
    border-color: var(--landa-border-base);
    color: var(--landa-color-title);
  }
}
.menuBtn__contentInner .menu_button_hamburger:active {
  transform: scale(0.98);
}

/* =========================================================
   アーカイブページ・レイアウト調整
========================================================= */
/* 【旧サイトからの引継ぎ】アーカイブページの本文抜粋を非表示 (ワイドレイアウト) */
#viewWide:checked ~ .archive .archive__item-infeedPc1 {
  display: none;
}

/* =========================================================
   WordPress 標準ブロックの調整
========================================================= */
/* 3カラムのズレ修正 */
.wp-block-columns:not(.is-not-stacked-on-mobile) > .wp-block-column {
  flex-basis: 0;
  flex-grow: 1;
  margin-top: 2rem;
}

/* =========================================================
   PMPro - 基本要素・見出し・リストの装飾リセット
========================================================= */
.pmpro_card h3.pmpro_card_title {
  background-image: none !important;
  margin: 36px 36px 12px 36px;
}

/* PMpro内のh2（アカウント情報などの見出し）の装飾を無効化 */
.content .pmpro_form_legend h2.pmpro_form_heading,
.content .pmpro h2.pmpro_section_title {
  background-color: transparent !important;
  border-left: none !important;
  border-bottom: none !important;
  padding: 0 !important;
}

/* PMProの特殊リスト等、背景を消したい例外への対応 */
.content ul.pmpro_list {
  background-color: transparent !important;
  padding: 0 !important;
  margin: 0 !important;
}

/* 念のため、左側の余白（The THORのアイコン用に空いてるスペース）をリセット */
.pmpro_card_content ul.pmpro_list > li {
  padding-left: 0 !important;
}

/* The THORのデフォルトリストアイコンを、マイアカウントのリストのみ非表示にする */
.pmpro_card_content ul.pmpro_list > li::before {
  display: none !important;
  content: "" !important;
}

/* =========================================================
   PMPro - プロフィール・フォーム画面のレイアウト調整
========================================================= */
/* テーマの余白指定を上書きして2カラムの崩れを修正 */
.content .pmpro_form_fields.pmpro_cols-2 > div.pmpro_form_field {
  margin-top: 0;
}

/* パスワード変更欄等の :first-child 余白崩れを修正 */
.content .pmpro_cols-2 .pmpro_form_field > :first-child {
  margin-top: auto;
}

/* プロフィール画面：必須項目のラベル末尾に赤いアスタリスクを追加 */
label[for=display_name]::after,
label[for=user_email]::after,
label[for=email]::after {
  content: " *";
  color: #e53935; /* 視認性の高い赤色 */
  font-weight: bold;
}

/* =========================================================
   【Land-A仕様】PMPro会員レベルによるメニュー出し分けシステム
========================================================= */
/* ① 有料プランに入っていない人（ゲスト）に、内部機能を強制非表示 */
body:not(.pmpro-has-membership) .land-a-member-only,
body:not(.pmpro-has-membership) .menuBtn__contentInner .wp-block-search {
  display: none !important;
}

/* ② 有料プランに入っている人（メンバー）に、不要なものを隠す用 */
body.pmpro-has-membership .land-a-guest-only {
  display: none !important;
}