@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
*/

/* =========================================================
   AI卑弥呼｜再構築版 style.css
   前提:
   - Google Fonts は functions.php 側で読み込み済み
   - 法的リンク帯は functions.php 側で出力済み
   - 背景動画は .himiko-global-bg 系クラスを使う
   ---------------------------------------------------------
   対象ページID:
   - 27: ホーム
   - 8 : 無料診断
   - 9 : 診断結果
   - 10: 年間運勢 完全版
   - 13: 特定商取引法に基づく表記
   - 11: 利用規約
   - 3 : プライバシーポリシー
   - 48: お問い合わせ
   ========================================================= */

/* =========================================================
   1. デザイントークン
   ========================================================= */
:root {
  --hm-gold: #bf9b54;
  --hm-gold-light: #d4af6e;
  --hm-gold-bright: #e8cc8a;
  --hm-navy: #0d1020;
  --hm-bg-dark: rgb(10, 10, 20);
  --hm-panel: rgba(10, 8, 22, 0.62);
  --hm-panel-strong: rgba(10, 8, 22, 0.72);
  --hm-panel-soft: rgba(10, 8, 22, 0.28);
  --hm-border-gold: rgba(191, 155, 84, 0.18);
  --hm-border-gold-soft: rgba(191, 155, 84, 0.10);
  --hm-text: rgba(230, 225, 215, 0.92);
  --hm-text-muted: rgba(200, 195, 180, 0.72);
  --hm-text-gold: rgba(212, 197, 160, 0.92);
  --hm-font-display-ja: "Klee One", "Noto Serif JP", serif;
  --hm-font-display-en: "Cinzel Decorative", "Noto Serif JP", serif;
  --hm-font-body: "Hiragino Kaku Gothic ProN", "Noto Sans JP", "Meiryo", sans-serif;
  --hm-content-width: 940px;
  --hm-article-width: 860px;
  --hm-radius: 14px;
  --hm-radius-sm: 10px;
}

/* =========================================================
   2. 全体ベース
   ========================================================= */
.grecaptcha-badge {
  visibility: hidden !important;
}

html {
  background: var(--hm-bg-dark);
}

body,
body.page,
body[class] {
  background: transparent !important;
  background-color: transparent !important;
  color: var(--hm-text);
  font-family: var(--hm-font-body);
}

#container,
#content,
.content,
.content-in,
#content-in,
.main,
main.main,
#main,
.wrap,
.article,
.entry-content {
  background: transparent !important;
  background-color: transparent !important;
}

main.main,
#main {
  z-index: auto !important;
}

#container,
.wrap {
  position: relative;
  z-index: 1;
}

.sidebar,
#sidebar,
.widget-sidebar {
  display: none !important;
}

/* 背景動画 */
.himiko-global-bg {
  position: fixed;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  overflow: hidden;
}

.himiko-global-bg__video {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.himiko-global-bg__overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(
    180deg,
    rgba(6, 6, 18, 0.82) 0%,
    rgba(8, 8, 22, 0.76) 40%,
    rgba(6, 6, 18, 0.86) 100%
  );
}

/* =========================================================
   3. フォント / 共通色
   ========================================================= */
.logo-text,
.logo-header .site-name-text,
.site-name-text {
  font-family: var(--hm-font-display-en) !important;
  letter-spacing: 0.08em;
}

h1,
h2,
h3,
.entry-title,
.himiko-nav-heading,
.himiko-result-header h2,
.himiko-premium-lp h1,
.himiko-premium-lp h2,
.himiko-premium-lp h3,
.himiko-ranking-page h1,
.himiko-hero-title {
  font-family: var(--hm-font-display-ja) !important;
}

.himiko-premium-subtitle,
.himiko-en-accent,
.himiko-ranking-type-label {
  font-family: var(--hm-font-display-en) !important;
  letter-spacing: 0.15em;
}

body .article,
body .article p,
body .entry-content,
body .entry-content p {
  color: var(--hm-text) !important;
}

body .article a {
  color: var(--hm-gold-light) !important;
}

body .article a:hover {
  color: var(--hm-gold-bright) !important;
}

/* =========================================================
   4. ヘッダー / フッター / 法的リンク帯
   ========================================================= */
#header-container,
#header-container-in,
#header,
.header,
.header-in,
.header-in.wrap,
.site-header,
.navi,
.navi-in,
#navi,
#navi-menu,
.navi-menu-content,
.navi-footer,
.navi-footer-in,
.logo-header {
  background: transparent !important;
  background-color: transparent !important;
  background-image: none !important;
  box-shadow: none !important;
  border: none !important;
}

#header-container::before,
#header-container::after,
.header::before,
.header::after,
.header-in::before,
.header-in::after,
.navi::before,
.navi::after {
  content: none !important;
  background: transparent !important;
  background-image: none !important;
  box-shadow: none !important;
}

.header .header-in.wrap {
  max-width: var(--hm-content-width) !important;
  margin-left: auto !important;
  margin-right: auto !important;
  padding-left: 24px !important;
  padding-right: 24px !important;
  box-sizing: border-box !important;
}

.navi .item a,
#navi .item a,
.navi-menu-content a {
  color: var(--hm-text-gold) !important;
  background: transparent !important;
}

.navi .item a:hover,
#navi .item a:hover {
  color: var(--hm-gold-light) !important;
  background: rgba(191, 155, 84, 0.06) !important;
}

#footer,
.footer,
.footer-in {
  background: rgba(6, 6, 18, 0.85) !important;
  border-top: 1px solid var(--hm-border-gold-soft);
}

.footer,
.footer a,
.copyright {
  color: var(--hm-text-muted) !important;
}

.breadcrumb {
  background: transparent !important;
  color: var(--hm-text-muted) !important;
  text-align: center !important;
}

.breadcrumb ul,
.breadcrumb ol {
  display: flex !important;
  justify-content: center !important;
  align-items: center !important;
  flex-wrap: wrap !important;
  gap: 0.35rem !important;
  margin: 0 auto !important;
  padding-left: 0 !important;
}

.breadcrumb li {
  float: none !important;
}

.breadcrumb a {
  color: var(--hm-gold-light) !important;
}

.admin-pv {
  display: none !important;
}

.himiko-legal-bar {
  display: block !important;
  max-width: var(--hm-content-width);
  margin: 24px auto 12px !important;
  padding: 14px 20px !important;
  text-align: center;
  font-size: 13px;
  line-height: 1.8;
  letter-spacing: 0.04em;
  color: var(--hm-text-muted);
  background: transparent;
  border-top: 1px solid rgba(191, 155, 84, 0.14);
  border-bottom: 1px solid rgba(191, 155, 84, 0.08);
}

.himiko-legal-bar a {
  color: var(--hm-text-muted) !important;
  text-decoration: none !important;
  padding: 0 8px;
  white-space: nowrap;
}

.himiko-legal-bar a:hover,
.himiko-legal-bar a:focus {
  color: var(--hm-gold-light) !important;
}

.himiko-legal-bar .himiko-legal-sep {
  color: rgba(191, 155, 84, 0.28);
  margin: 0 2px;
  user-select: none;
}

.himiko-footer-links,
.himiko-legal-links-inline,
.article .himiko-footer-links {
  display: none !important;
}

/* =========================================================
   5. 共通1カラム幅
   ========================================================= */
body.page-id-8 .main,
body.page-id-9 .main,
body.page-id-10 .main,
body.single-ranking .main,
body.page-id-3 .main,
body.page-id-11 .main,
body.page-id-13 .main,
body.page-id-48 .main,
body.page-id-126 .main {
  width: 100% !important;
  max-width: var(--hm-content-width) !important;
  margin: 0 auto !important;
  float: none !important;
}

/* /terms/ を基準に、ロゴ下〜見出しの余白を主要ページで統一 */
body.page-id-8 .main,
body.page-id-9 .main,
body.page-id-10 .main,
body.single-ranking .main,
body.page-id-3 .main,
body.page-id-11 .main,
body.page-id-13 .main,
body.page-id-48 .main,
body.page-id-126 .main {
  padding: 32px 20px 0 !important;
}

#post-8.article,
#post-9.article,
#post-10.article,
body.single-ranking article,
body.page-id-3 .article,
body.page-id-11 .article,
body.page-id-13 .article,
body.page-id-48 .article,
body.page-id-126 .article {
  width: 100% !important;
  max-width: var(--hm-article-width) !important;
  margin-left: auto !important;
  margin-right: auto !important;
  margin-top: 0 !important;
  margin-bottom: 0 !important;
  padding: 40px 32px !important;
  border: none !important;
  box-shadow: none !important;
  box-sizing: border-box !important;
}

body.page-id-8 .wrap,
body.page-id-9 .wrap,
body.page-id-10 .wrap,
body.single-ranking .wrap,
body.page-id-3 .wrap,
body.page-id-11 .wrap,
body.page-id-13 .wrap,
body.page-id-48 .wrap,
body.page-id-126 .wrap {
  max-width: var(--hm-content-width) !important;
  margin: 0 auto !important;
}

/* =========================================================
   6. 共通ボタン
   ========================================================= */
.himiko-btn-primary,
a.himiko-btn-primary,
button.himiko-btn-primary,
input.himiko-btn-primary,
.himiko-btn-checkout,
a.himiko-btn-checkout,
button.himiko-btn-checkout,
.himiko-btn-purchase,
a.himiko-btn-purchase,
button.himiko-btn-purchase,
.himiko-hero-btn,
a.himiko-hero-btn,
a.himiko-premium-btn {
  display: inline-block !important;
  box-sizing: border-box !important;
  background: linear-gradient(135deg, var(--hm-gold) 0%, var(--hm-gold-light) 50%, var(--hm-gold) 100%) !important;
  color: var(--hm-navy) !important;
  -webkit-text-fill-color: var(--hm-navy) !important;
  font-family: var(--hm-font-display-ja) !important;
  font-size: 18px !important;
  font-weight: 600 !important;
  line-height: 1.3 !important;
  letter-spacing: 0.12em !important;
  text-align: center !important;
  text-decoration: none !important;
  padding: 18px 56px !important;
  border: none !important;
  border-radius: 50px !important;
  position: relative !important;
  overflow: hidden !important;
  cursor: pointer !important;
  box-shadow: 0 4px 20px rgba(191, 155, 84, 0.30), 0 0 40px rgba(191, 155, 84, 0.10) !important;
  transition: all 0.25s cubic-bezier(0.25, 0.46, 0.45, 0.94) !important;
}

.himiko-btn-primary:visited,
a.himiko-btn-primary:visited,
.himiko-hero-btn:visited,
a.himiko-hero-btn:visited,
a.himiko-premium-btn:visited {
  color: var(--hm-navy) !important;
  -webkit-text-fill-color: var(--hm-navy) !important;
}

.himiko-btn-primary::before,
a.himiko-btn-primary::before,
button.himiko-btn-primary::before,
.himiko-btn-checkout::before,
a.himiko-btn-checkout::before,
button.himiko-btn-checkout::before,
.himiko-hero-btn::before,
a.himiko-hero-btn::before,
a.himiko-premium-btn::before {
  content: "" !important;
  position: absolute !important;
  top: 0 !important;
  left: -100% !important;
  width: 100% !important;
  height: 100% !important;
  background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.30), transparent) !important;
  transition: left 0.6s ease !important;
}

.himiko-btn-primary:hover,
.himiko-btn-primary:focus,
a.himiko-btn-primary:hover,
a.himiko-btn-primary:focus,
button.himiko-btn-primary:hover,
button.himiko-btn-primary:focus,
.himiko-btn-checkout:hover,
.himiko-btn-checkout:focus,
.himiko-hero-btn:hover,
.himiko-hero-btn:focus,
a.himiko-premium-btn:hover,
a.himiko-premium-btn:focus {
  background: linear-gradient(135deg, var(--hm-gold-light) 0%, var(--hm-gold-bright) 50%, var(--hm-gold-light) 100%) !important;
  color: var(--hm-navy) !important;
  -webkit-text-fill-color: var(--hm-navy) !important;
  transform: translateY(-2px) scale(1.01) !important;
  box-shadow: 0 8px 32px rgba(191, 155, 84, 0.50), 0 0 60px rgba(191, 155, 84, 0.20), inset 0 1px 0 rgba(255, 255, 255, 0.15) !important;
}

.himiko-btn-primary:hover::before,
a.himiko-btn-primary:hover::before,
button.himiko-btn-primary:hover::before,
.himiko-btn-checkout:hover::before,
.himiko-hero-btn:hover::before,
a.himiko-premium-btn:hover::before {
  left: 100% !important;
}

.himiko-btn-secondary,
a.himiko-btn-secondary {
  display: inline-block;
  background: transparent !important;
  color: var(--hm-gold-light) !important;
  -webkit-text-fill-color: var(--hm-gold-light) !important;
  font-family: var(--hm-font-display-ja);
  font-size: 15px;
  font-weight: 600;
  letter-spacing: 0.1em;
  padding: 14px 40px;
  border: 1.5px solid var(--hm-gold) !important;
  border-radius: 50px;
  text-decoration: none !important;
  transition: all 0.25s ease;
}

.himiko-btn-secondary:hover,
a.himiko-btn-secondary:hover {
  background: rgba(191, 155, 84, 0.12) !important;
  transform: translateY(-1px);
  box-shadow: 0 4px 16px rgba(191, 155, 84, 0.20);
}

/* =========================================================
   7. トップページ
   ========================================================= */
body.page-id-27 .article,
body.page-id-27 .entry-content,
body.page-id-27 .main,
body.page-id-27 .content-in,
body.page-id-27 #content-in {
  max-width: 100% !important;
  margin: 0 !important;
  padding: 0 !important;
  border: none !important;
  box-shadow: none !important;
}

body.page-id-27 .entry-title,
body.page-id-27 .article-header,
body.page-id-27 .sns-share,
body.page-id-27 .sns-follow,
body.page-id-27 .post-date,
body.page-id-27 .post-update,
body.page-id-27 .author-info,
body.page-id-27 .breadcrumb,
body.page-id-27 .under-entry-content,
body.page-id-27 .related-entries,
body.page-id-27 .pager-post-navi,
body.page-id-27 .comment-area,
body.page-id-27 .footer-meta,
body.page-id-27 .widget_search,
body.page-id-27 .widget_recent_entries,
body.page-id-27 .widget_recent_comments,
body.page-id-27 .widget_archive,
body.page-id-27 .widget_categories,
body.page-id-27 .mobile-footer-menu-buttons,
body.page-id-27 .eye-catch-wrap {
  display: none !important;
}

.himiko-home {
  position: relative;
  z-index: 1;
  text-align: center;
  color: var(--hm-text-gold);
}

.himiko-hero,
.himiko-nav-section,
.himiko-premium-section,
.himiko-footer-links {
  position: relative;
}

.himiko-hero {
  padding: 80px 20px 60px;
  background: radial-gradient(ellipse at center, rgba(191, 155, 84, 0.08) 0%, transparent 70%);
}

.himiko-hero::after {
  content: "";
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 120px;
  height: 2px;
  background: linear-gradient(90deg, transparent, var(--hm-gold), transparent);
  pointer-events: none;
}

.himiko-hero-site {
  font-size: 16px;
  letter-spacing: 0.4em;
  color: rgba(191, 155, 84, 0.7);
  margin-bottom: 16px;
  font-family: var(--hm-font-display-ja) !important;
}

body.page-id-27 .himiko-hero-title,
body.page-id-27 .article h2.himiko-hero-title,
body.page-id-27 .entry-content h2.himiko-hero-title,
body.page-id-27 h2.himiko-hero-title {
  border: none !important;
  padding: 0 !important;
  margin: 0 0 24px 0 !important;
  background: none !important;
  text-align: center !important;
  font-size: 28px !important;
  line-height: 1.6 !important;
  letter-spacing: 0.15em !important;
  color: var(--hm-gold) !important;
  font-family: var(--hm-font-display-ja) !important;
  font-weight: 600 !important;
  text-shadow: 0 0 20px rgba(191, 155, 84, 0.2) !important;
}

.himiko-hero-desc {
  font-size: 14px;
  line-height: 2;
  color: rgba(212, 197, 160, 0.8);
  margin-bottom: 40px;
  font-family: var(--hm-font-body);
}

body.page-id-27 .himiko-hero .himiko-hero-img,
body.page-id-27 img.himiko-hero-img {
  display: block !important;
  width: 293px !important;
  height: auto !important;
  max-width: 80% !important;
  margin: 24px auto 28px !important;
  object-fit: contain;
  border: none;
}

.himiko-nav-section {
  max-width: 700px;
  margin: 0 auto;
  padding: 50px 20px;
  background: rgba(10, 8, 22, 0.28);
}

body.page-id-27 .himiko-nav-heading,
body.page-id-27 .article h3.himiko-nav-heading,
body.page-id-27 .entry-content h3.himiko-nav-heading,
body.page-id-27 h3.himiko-nav-heading {
  position: relative;
  border: none !important;
  padding: 0 !important;
  background: none !important;
  text-align: center !important;
  font-size: 18px !important;
  color: var(--hm-gold) !important;
  margin: 0 0 30px 0 !important;
  font-family: var(--hm-font-display-ja) !important;
  font-weight: 600 !important;
}

body.page-id-27 .himiko-nav-heading::after {
  content: "";
  position: absolute;
  bottom: -8px;
  left: 50%;
  transform: translateX(-50%);
  width: 40px;
  height: 1px;
  background: rgba(191, 155, 84, 0.5);
}

.himiko-nav-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
  margin-top: 10px;
}

.himiko-nav-card,
a.himiko-nav-card {
  display: flex !important;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 28px 12px;
  background: rgba(20, 20, 40, 0.7);
  border: 1px solid rgba(191, 155, 84, 0.2);
  border-radius: 12px;
  text-decoration: none !important;
  transition: all 0.3s ease;
  color: var(--hm-text-gold) !important;
}

.himiko-nav-card:hover,
a.himiko-nav-card:hover {
  border-color: rgba(191, 155, 84, 0.5);
  background: rgba(30, 28, 50, 0.8);
  transform: translateY(-3px);
  box-shadow: 0 8px 25px rgba(0, 0, 0, 0.3);
}

.himiko-nav-icon {
  display: block;
  font-size: 28px;
  margin-bottom: 12px;
}

.himiko-nav-label {
  font-size: 13px;
  line-height: 1.6;
  letter-spacing: 0.1em;
  font-family: var(--hm-font-body);
  color: var(--hm-text-gold) !important;
}

.himiko-premium-section {
  position: relative;
  overflow: hidden;
  border-radius: 16px;
  margin: 16px auto 24px !important;
  width: min(1280px, calc(100% - 48px)) !important;
  max-width: calc(100% - 48px) !important;
  padding: 56px 24px 48px !important;
  background: rgba(10, 8, 22, 0.62) !important;
  border: 1px solid rgba(191, 155, 84, 0.15);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
}

.himiko-premium-section::before {
  content: "";
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 80px;
  height: 2px;
  background: linear-gradient(90deg, transparent, rgba(191, 155, 84, 0.6), transparent);
}

.himiko-premium-content {
  position: relative;
  z-index: 2;
}

body.page-id-27 .himiko-premium-section .himiko-nav-heading {
  color: var(--hm-text-gold) !important;
  text-shadow: 0 0 20px rgba(191, 155, 84, 0.3);
  margin-bottom: 8px;
}

.himiko-premium-subtitle {
  font-size: 13px;
  color: rgba(191, 155, 84, 0.6);
  letter-spacing: 0.2em;
  margin-bottom: 28px;
}

.himiko-premium-section .himiko-premium-desc {
  color: rgba(220, 210, 190, 0.85) !important;
}

.himiko-premium-features {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 12px;
  max-width: 460px;
  margin: 0 auto 32px;
  text-align: left;
}

.himiko-feature-item {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 12px 16px;
  background: rgba(191, 155, 84, 0.06);
  border: 1px solid rgba(191, 155, 84, 0.10);
  border-radius: 10px;
  font-size: 13px;
  color: var(--hm-text-gold);
  font-family: var(--hm-font-body);
  line-height: 1.5;
}

.himiko-feature-icon {
  font-size: 20px;
  flex-shrink: 0;
}

/* top premium 背景画像 img2 */
body.page-id-27 .himiko-premium-section .himiko-premium-visual {
  position: absolute !important;
  top: 0 !important;
  right: 0 !important;
  height: 100% !important;
  width: auto !important;
  max-width: 48% !important;
  object-fit: cover;
  object-position: right center;
  opacity: 0.42;
  pointer-events: none;
  z-index: 0;
  -webkit-mask-image: linear-gradient(to left, rgba(0, 0, 0, 1) 0%, rgba(0, 0, 0, 1) 50%, rgba(0, 0, 0, 0.65) 75%, rgba(0, 0, 0, 0) 100%);
          mask-image: linear-gradient(to left, rgba(0, 0, 0, 1) 0%, rgba(0, 0, 0, 1) 50%, rgba(0, 0, 0, 0.65) 75%, rgba(0, 0, 0, 0) 100%);
}

body.page-id-27 .himiko-home .himiko-footer-links {
  display: none !important;
}

body.page-id-27 .himiko-legal-bar,
body.home .himiko-legal-bar {
  margin-top: 20px !important;
  margin-bottom: 8px !important;
}

body.page-id-27 #footer,
body.home #footer {
  margin-top: 0 !important;
  padding-top: 8px !important;
}

body.page-id-27 #footer .footer-top,
body.home #footer .footer-top {
  margin-top: 0 !important;
}

/* =========================================================
   8. ページタイトル共通
   ========================================================= */
body.page-id-8 .entry-title,
body.page-id-9 .entry-title,
body.page-id-10 .entry-title,
body.single-ranking h1,
body.page-id-3 .article .entry-title,
body.page-id-11 .article .entry-title,
body.page-id-13 .article .entry-title,
body.page-id-48 .article .entry-title,
body.page-id-126 .article .entry-title,
body.page-id-3 .article h1.entry-title,
body.page-id-11 .article h1.entry-title,
body.page-id-13 .article h1.entry-title,
body.page-id-48 .article h1.entry-title,
body.page-id-126 .article h1.entry-title {
  font-family: var(--hm-font-display-ja) !important;
  font-size: 28px !important;
  font-weight: 600 !important;
  color: var(--hm-text-gold) !important;
  text-align: center !important;
  margin: 16px 0 24px !important;
  padding-bottom: 16px !important;
  border-bottom: 1px solid var(--hm-border-gold) !important;
  letter-spacing: 0.06em;
  text-shadow: 0 0 24px rgba(191, 155, 84, 0.15);
  background: transparent !important;
}

/* =========================================================
   9. 無料診断ページ
   ========================================================= */
body.page-id-8 .sns-share,
body.page-id-8 .sns-follow,
body.page-id-8 .date-tags,
body.page-id-8 .author-info,
body.page-id-8 .eye-catch-wrap,
body.page-id-8 .article-footer,
body.page-id-8 .under-entry-content {
  display: none !important;
}

body.page-id-8 .entry-content {
  max-width: 640px !important;
  margin: 0 auto 60px !important;
}

body.page-id-8 .entry-content form {
  background: rgba(10, 8, 22, 0.60);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  border: 1px solid var(--hm-border-gold);
  border-radius: var(--hm-radius);
  padding: 48px 36px 40px;
  margin: 32px auto;
  position: relative;
  text-align: center;
}

body.page-id-8 .entry-content form::before,
body.page-id-8 .entry-content form::after {
  content: "";
  position: absolute;
  width: 28px;
  height: 28px;
  border-color: rgba(191, 155, 84, 0.45);
  border-style: solid;
}

body.page-id-8 .entry-content form::before {
  top: 8px;
  left: 8px;
  border-width: 1.5px 0 0 1.5px;
}

body.page-id-8 .entry-content form::after {
  bottom: 8px;
  right: 8px;
  border-width: 0 1.5px 1.5px 0;
}

body.page-id-8 .entry-content label {
  display: block;
  color: var(--hm-text-gold) !important;
  font-family: var(--hm-font-display-ja);
  font-size: 14px;
  font-weight: 600;
  margin-top: 24px;
  margin-bottom: 8px;
  text-align: left;
  letter-spacing: 0.05em;
}

body.page-id-8 .entry-content label:first-of-type {
  margin-top: 0;
}

body.page-id-8 .entry-content input[type="date"],
body.page-id-8 .entry-content select {
  width: 100% !important;
  padding: 14px 16px !important;
  background: rgba(255, 255, 255, 0.90) !important;
  background-color: rgba(255, 255, 255, 0.90) !important;
  border: 1px solid rgba(191, 155, 84, 0.45) !important;
  border-radius: var(--hm-radius-sm) !important;
  color: #1a1a2e !important;
  font-size: 16px !important;
  font-family: var(--hm-font-body) !important;
  transition: border-color 0.2s, box-shadow 0.2s;
  appearance: none;
  -webkit-appearance: none;
}

body.page-id-8 .entry-content input[type="date"]:focus,
body.page-id-8 .entry-content select:focus {
  border-color: var(--hm-gold) !important;
  box-shadow: 0 0 0 2px rgba(191, 155, 84, 0.25) !important;
  outline: none;
}

body.page-id-8 .entry-content select {
  padding-right: 40px !important;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%23bf9b54' stroke-width='1.5' fill='none'/%3E%3C/svg%3E") !important;
  background-repeat: no-repeat !important;
  background-position: right 14px center !important;
}

body.page-id-8 .entry-content input[type="date"]::-webkit-calendar-picker-indicator {
  cursor: pointer;
  filter: invert(63%) sepia(46%) saturate(420%) hue-rotate(7deg) brightness(92%) contrast(88%);
  opacity: 1;
}

body.page-id-8 .entry-content label:has(input[type="radio"]) {
  display: inline-flex !important;
  align-items: center;
  margin-right: 20px;
  margin-top: 0;
  font-size: 15px;
  color: var(--hm-text) !important;
  cursor: pointer;
}

body.page-id-8 .entry-content input[type="radio"] {
  accent-color: var(--hm-gold);
  margin-right: 6px;
}

body.page-id-8 .entry-content button[type="submit"],
body.page-id-8 .entry-content input[type="submit"] {
  display: block !important;
  width: 310px !important;
  max-width: 100% !important;
  margin: 36px auto 0 !important;
  box-sizing: border-box !important;
}

/* =========================================================
   10. ランキングページ
   ========================================================= */
body.single-ranking .sns-share,
body.single-ranking .sns-follow,
body.single-ranking .date-tags,
body.single-ranking .author-info,
body.single-ranking .eye-catch-wrap,
body.single-ranking .article-footer,
body.single-ranking .under-entry-content {
  display: none !important;
}

.himiko-ranking-page {
  padding-bottom: 60px !important;
}

.himiko-ranking-full {
  background: var(--hm-panel);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  border: 1px solid var(--hm-border-gold);
  border-radius: var(--hm-radius);
  padding: 32px 24px;
  margin: 32px 0 40px;
}

ol.himiko-ranking-list {
  list-style: none !important;
  padding: 0 !important;
  margin: 0 !important;
}

.himiko-ranking-entry {
  display: grid;
  grid-template-columns: 56px 1fr auto !important;
  grid-template-rows: auto auto;
  gap: 0 16px;
  align-items: center;
  padding: 20px 16px;
  border-bottom: 1px solid rgba(191, 155, 84, 0.10);
  transition: background 0.2s;
}

.himiko-ranking-entry:last-child {
  border-bottom: none;
}

.himiko-ranking-entry:hover {
  background: rgba(191, 155, 84, 0.04);
}

.himiko-ranking-entry .rank,
.himiko-ranking-entry .rank-no,
.himiko-ranking-entry > span:first-child {
  grid-row: 1 / 3;
  min-width: 56px !important;
  width: 56px !important;
  white-space: nowrap !important;
  flex-shrink: 0 !important;
  display: inline-block !important;
  text-align: center !important;
  font-family: var(--hm-font-display-en);
  font-size: 22px;
  font-weight: 400;
  color: var(--hm-text-muted);
}

.himiko-ranking-entry.rank-1 .rank,
.himiko-ranking-entry.rank-2 .rank,
.himiko-ranking-entry.rank-3 .rank {
  color: var(--hm-gold) !important;
  font-size: 26px;
  text-shadow: 0 0 12px rgba(191, 155, 84, 0.3);
}

.himiko-ranking-entry .zodiac {
  grid-column: 2;
  font-family: var(--hm-font-display-ja);
  font-size: 17px;
  font-weight: 600;
  color: var(--hm-text);
}

.himiko-ranking-entry .score {
  grid-column: 3;
  grid-row: 1 / 3;
  text-align: right;
  font-family: var(--hm-font-display-en);
  font-size: 20px;
  font-weight: 400;
  color: var(--hm-gold-light);
}

.himiko-ranking-entry .comment {
  grid-column: 2;
  margin: 4px 0 0 !important;
  font-size: 13px;
  line-height: 1.5;
  color: var(--hm-text-muted);
}

.himiko-cta-block {
  text-align: center;
  margin: 48px 0 0;
  padding: 40px 24px;
  background: var(--hm-panel);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  border: 1px solid var(--hm-border-gold);
  border-radius: var(--hm-radius);
}

.himiko-cta-block p {
  font-family: var(--hm-font-display-ja);
  font-size: 18px;
  color: var(--hm-text-gold) !important;
  margin-bottom: 24px !important;
  letter-spacing: 0.05em;
}

/* =========================================================
   11. プレミアムページ
   ========================================================= */
body.page-id-10 .sns-share,
body.page-id-10 .sns-follow,
body.page-id-10 .date-tags,
body.page-id-10 .author-info,
body.page-id-10 .eye-catch-wrap,
body.page-id-10 .article-footer,
body.page-id-10 .under-entry-content,
body.page-id-10 .toc,
body.page-id-10 .toc-content {
  display: none !important;
}

body.page-id-10 .entry-content {
  max-width: 640px !important;
  margin: 0 auto !important;
  padding-bottom: 60px !important;
}

body.page-id-10 h1.entry-title,
body.page-id-10 .entry-header h1.entry-title,
body.page-id-10 .entry-title {
  display: block !important;
  visibility: visible !important;
  height: auto !important;
  overflow: visible !important;
  margin: 16px 0 24px !important;
  padding-bottom: 16px !important;
  font-family: var(--hm-font-display-ja) !important;
  font-size: 28px !important;
  font-weight: 600 !important;
  line-height: 1.4 !important;
  letter-spacing: 0.06em !important;
  color: var(--hm-text-gold) !important;
  text-align: center !important;
  background: transparent !important;
  border: none !important;
  border-bottom: 1px solid var(--hm-border-gold) !important;
  text-shadow: 0 0 24px rgba(191, 155, 84, 0.15) !important;
}

.himiko-premium-lp {
  text-align: center;
}

#post-10 .himiko-premium-lp > h2:first-child {
  display: none !important;
}

#post-10 .himiko-premium-lp h2 {
  font-family: var(--hm-font-display-ja) !important;
  font-size: 28px !important;
  font-weight: 600 !important;
  color: var(--hm-text-gold) !important;
  margin: 0 0 16px !important;
  padding: 0 0 12px 0 !important;
  border: none !important;
  border-bottom: 1px solid var(--hm-border-gold) !important;
  background: transparent !important;
  text-align: center !important;
  text-shadow: 0 0 20px rgba(191, 155, 84, 0.15);
}

body.page-id-10 figure.wp-block-image.himiko-premium-hero-img,
body.page-id-10 figure.wp-block-image.aligncenter.himiko-premium-hero-img {
  position: relative;
  z-index: 1;
  display: block !important;
  width: 100% !important;
  max-width: 342px !important;
  margin: 24px auto 0 !important;
  text-align: center !important;
  float: none !important;
}

body.page-id-10 figure.wp-block-image.himiko-premium-hero-img img {
  display: block !important;
  width: 100% !important;
  max-width: 342px !important;
  max-height: 451px !important;
  height: auto !important;
  margin: 0 auto !important;
  object-fit: contain;
}

body.page-id-10 .himiko-premium-features {
  position: relative !important;
  z-index: 3 !important;
  display: block !important;
  max-width: 520px !important;
  margin: -80px auto 40px !important;
  padding: 56px 32px 40px !important;
  background: rgba(10, 10, 24, 0.62) !important;
  backdrop-filter: blur(2px);
  -webkit-backdrop-filter: blur(2px);
  border: 1px solid var(--hm-border-gold);
  border-radius: var(--hm-radius);
  text-align: left;
}

body.page-id-10 .himiko-premium-features h3 {
  font-family: var(--hm-font-display-ja) !important;
  font-size: 22px !important;
  color: var(--hm-text-gold) !important;
  margin: 0 0 24px !important;
  text-align: center;
  background: none !important;
  border: none !important;
  outline: none !important;
  box-shadow: none !important;
  border-radius: 0 !important;
  padding: 0 !important;
  position: relative;
}

body.page-id-10 .himiko-premium-features h3::after {
  content: "";
  display: block;
  width: 56px;
  height: 1px;
  margin: 10px auto 0;
  background: rgba(191, 155, 84, 0.5);
}

body.page-id-10 .himiko-premium-features ul {
  list-style: none !important;
  padding: 0 !important;
  margin: 0 !important;
  columns: 1 !important;
  -webkit-columns: 1 !important;
}

body.page-id-10 .himiko-premium-features li {
  position: relative;
  display: list-item !important;
  width: 100% !important;
  margin: 6px 0 !important;
  padding: 14px 16px 14px 40px;
  border-bottom: 1px solid rgba(191, 155, 84, 0.08);
  color: var(--hm-text);
  font-size: 15px;
  line-height: 1.7;
}

body.page-id-10 .himiko-premium-features li:last-child {
  border-bottom: none;
}

body.page-id-10 .himiko-premium-features li::before {
  content: "\2727";
  position: absolute;
  left: 12px;
  top: 14px;
  color: var(--hm-gold);
  font-size: 16px;
}

#post-10 .himiko-premium-pricing {
  background: var(--hm-panel);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  border: 1px solid var(--hm-border-gold);
  border-radius: var(--hm-radius);
  padding: 48px 32px;
  margin: 40px auto;
  max-width: 520px;
  text-align: center;
}

.himiko-premium-pricing .original-price {
  font-size: 16px;
  color: var(--hm-text-muted) !important;
  text-decoration: line-through;
  margin-bottom: 8px !important;
}

.himiko-premium-pricing .sale-badge {
  display: inline-block;
  background: linear-gradient(135deg, rgba(191, 155, 84, 0.2), rgba(191, 155, 84, 0.1));
  border: 1px solid var(--hm-border-gold);
  border-radius: 20px;
  padding: 6px 20px;
  font-size: 14px;
  font-weight: 700;
  color: var(--hm-gold-light) !important;
  margin-bottom: 12px !important;
}

.himiko-premium-pricing .sale-price {
  font-family: var(--hm-font-display-en);
  font-size: 40px;
  font-weight: 400;
  color: var(--hm-gold) !important;
  margin-bottom: 4px !important;
  line-height: 1.2;
}

.himiko-premium-pricing .sale-price .tax-note {
  font-size: 14px;
  font-family: var(--hm-font-body);
  color: var(--hm-text-muted) !important;
}

.himiko-premium-lp .himiko-btn-checkout {
  margin: 32px auto 24px !important;
  min-width: 280px;
}

.himiko-legal-note {
  font-size: 12px !important;
  color: var(--hm-text-muted) !important;
  text-align: center;
  margin-top: 12px !important;
}

.himiko-legal-note a {
  color: var(--hm-gold-light) !important;
  text-decoration: underline;
}

/* =========================================================
   12. 診断結果ページ
   ========================================================= */
body.page-id-9 .sns-share,
body.page-id-9 .sns-follow,
body.page-id-9 .date-tags,
body.page-id-9 .author-info,
body.page-id-9 .eye-catch-wrap,
body.page-id-9 .article-footer,
body.page-id-9 .under-entry-content {
  display: none !important;
}

body.page-id-9 .entry-content {
  max-width: 640px !important;
  margin: 0 auto !important;
  padding-bottom: 60px !important;
}

.himiko-result-header {
  text-align: center;
  padding: 40px 24px 24px;
  margin-bottom: 0;
}

.himiko-result-header h2 {
  font-family: var(--hm-font-display-ja) !important;
  font-size: 28px !important;
  font-weight: 600 !important;
  color: var(--hm-text-gold) !important;
  margin-bottom: 8px !important;
  text-shadow: 0 0 20px rgba(191, 155, 84, 0.2);
  background: none !important;
  border: none !important;
  padding: 0 !important;
}

.himiko-result-header p {
  font-size: 14px;
  color: var(--hm-text-muted) !important;
  letter-spacing: 0.1em;
}

.himiko-result-free {
  background: var(--hm-panel);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  border: 1px solid var(--hm-border-gold);
  border-radius: var(--hm-radius);
  padding: 0 32px 40px;
  margin: 32px 0;
  overflow: hidden;
}

.himiko-score-total {
  text-align: center;
  padding: 32px 0 24px;
  border-bottom: 1px solid rgba(191, 155, 84, 0.12);
  margin-bottom: 24px;
}

.himiko-score-total .label {
  display: block;
  font-family: var(--hm-font-display-ja);
  font-size: 14px;
  color: var(--hm-text-muted);
  letter-spacing: 0.1em;
  margin-bottom: 8px;
}

.himiko-score-total .score {
  font-family: var(--hm-font-display-en);
  font-size: 64px;
  font-weight: 400;
  color: var(--hm-gold);
  line-height: 1;
  text-shadow: 0 0 30px rgba(191, 155, 84, 0.25);
}

.himiko-score-total .unit {
  font-size: 20px;
  color: var(--hm-text-muted);
  font-weight: 400;
  margin-left: 4px;
}

.himiko-scores-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 12px;
  margin-bottom: 24px;
}

.himiko-score-item {
  background: rgba(191, 155, 84, 0.05) !important;
  border: 1px solid rgba(191, 155, 84, 0.10);
  border-radius: var(--hm-radius-sm);
  padding: 16px;
  text-align: center;
}

.himiko-score-item .label {
  display: block;
  font-family: var(--hm-font-display-ja);
  font-size: 13px;
  color: var(--hm-text-muted);
  margin-bottom: 6px;
  letter-spacing: 0.05em;
}

.himiko-score-item .stars {
  font-size: 18px;
  color: var(--hm-gold);
  letter-spacing: 2px;
}

.himiko-lucky-color {
  text-align: center;
  padding: 16px 0;
  margin-bottom: 20px;
  border-top: 1px solid rgba(191, 155, 84, 0.08);
  border-bottom: 1px solid rgba(191, 155, 84, 0.08);
}

.himiko-lucky-color .label {
  font-size: 13px;
  color: var(--hm-text-muted);
  margin-right: 8px;
}

.himiko-lucky-color span:last-child {
  font-family: var(--hm-font-display-ja);
  font-size: 16px;
  color: var(--hm-text-gold);
  font-weight: 600;
}

.himiko-message-free {
  font-size: 15px;
  line-height: 1.8;
  color: var(--hm-text) !important;
  padding: 16px 8px;
  margin-bottom: 20px;
}

.himiko-share {
  display: flex;
  justify-content: center;
  gap: 12px;
  padding-top: 16px;
  border-top: 1px solid rgba(191, 155, 84, 0.08);
}

.himiko-share-btn {
  display: inline-flex !important;
  align-items: center;
  padding: 10px 20px !important;
  border-radius: 50px !important;
  font-size: 13px !important;
  font-weight: 600 !important;
  text-decoration: none !important;
  transition: all 0.2s ease;
}

.himiko-share-x {
  background: rgba(255, 255, 255, 0.08) !important;
  color: var(--hm-text) !important;
  border: 1px solid rgba(255, 255, 255, 0.15) !important;
}

.himiko-share-line {
  background: rgba(6, 199, 85, 0.12) !important;
  color: #06c755 !important;
  border: 1px solid rgba(6, 199, 85, 0.2) !important;
}

.himiko-share-btn:hover {
  transform: translateY(-1px);
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.2);
}

.himiko-result-paid {
  position: relative;
  margin: 0 0 32px;
  border-radius: var(--hm-radius);
  overflow: hidden;
}

.himiko-result-paid--locked .himiko-blur-overlay {
  filter: blur(6px);
  -webkit-filter: blur(6px);
  opacity: 0.5;
  padding: 32px;
  user-select: none;
  pointer-events: none;
}

.himiko-result-paid--locked .himiko-blur-overlay .himiko-dummy-text p {
  color: var(--hm-text-muted) !important;
  font-size: 14px;
  line-height: 1.8;
  margin-bottom: 16px !important;
}

.himiko-cta-overlay {
  background: linear-gradient(180deg, rgba(10, 8, 22, 0.4) 0%, rgba(10, 8, 22, 0.85) 30%, rgba(10, 8, 22, 0.95) 100%);
  padding: 48px 24px 40px;
  text-align: center;
  border: 1px solid var(--hm-border-gold);
  border-radius: var(--hm-radius);
}

.himiko-cta-text {
  font-family: var(--hm-font-display-ja) !important;
  font-size: 20px !important;
  color: var(--hm-text-gold) !important;
  margin-bottom: 16px !important;
  letter-spacing: 0.05em;
}

.himiko-cta-price {
  margin-bottom: 24px !important;
}

.himiko-cta-price .original-price {
  font-size: 14px;
  color: var(--hm-text-muted) !important;
  text-decoration: line-through;
  margin-right: 12px;
}

.himiko-cta-price .sale-price {
  font-family: var(--hm-font-display-en);
  font-size: 28px;
  font-weight: 400;
  color: var(--hm-gold) !important;
}

.himiko-cta-price .tax-note {
  font-size: 12px;
  color: var(--hm-text-muted) !important;
}

.himiko-nav-buttons,
body.page-id-9 .himiko-nav-buttons,
body.single-ranking .himiko-nav-buttons {
  border-top: 1px solid rgba(191, 155, 84, 0.18) !important;
  padding-top: 24px !important;
  margin-top: 32px !important;
}

/* =========================================================
   13. 法的ページ
   ========================================================= */
body.page-id-3 .sns-share,
body.page-id-11 .sns-share,
body.page-id-13 .sns-share,
body.page-id-48 .sns-share,
body.page-id-3 .sns-follow,
body.page-id-11 .sns-follow,
body.page-id-13 .sns-follow,
body.page-id-48 .sns-follow,
body.page-id-3 .date-tags,
body.page-id-11 .date-tags,
body.page-id-13 .date-tags,
body.page-id-48 .date-tags,
body.page-id-3 .author-info,
body.page-id-11 .author-info,
body.page-id-13 .author-info,
body.page-id-48 .author-info,
body.page-id-3 .eye-catch-wrap,
body.page-id-11 .eye-catch-wrap,
body.page-id-13 .eye-catch-wrap,
body.page-id-48 .eye-catch-wrap,
body.page-id-3 .article-footer,
body.page-id-11 .article-footer,
body.page-id-13 .article-footer,
body.page-id-48 .article-footer,
body.page-id-3 .under-entry-content,
body.page-id-11 .under-entry-content,
body.page-id-13 .under-entry-content,
body.page-id-48 .under-entry-content,
body.page-id-3 .related-entries,
body.page-id-11 .related-entries,
body.page-id-13 .related-entries,
body.page-id-48 .related-entries,
body.page-id-3 .pager-post-navi,
body.page-id-11 .pager-post-navi,
body.page-id-13 .pager-post-navi,
body.page-id-48 .pager-post-navi {
  display: none !important;
}

body.page-id-3 .article h2,
body.page-id-11 .article h2,
body.page-id-13 .article h2,
body.page-id-48 .article h2,
body.page-id-3 .article h3,
body.page-id-11 .article h3,
body.page-id-13 .article h3,
body.page-id-48 .article h3,
body.page-id-3 .article h4,
body.page-id-11 .article h4,
body.page-id-13 .article h4,
body.page-id-48 .article h4 {
  color: var(--hm-text-gold) !important;
  border: none !important;
  padding: 8px 0 !important;
  background: transparent !important;
  font-family: var(--hm-font-display-ja) !important;
}

/* 特商法ページの table */
body.page-id-13 .article table,
body.page-id-13 .article thead,
body.page-id-13 .article tbody,
body.page-id-13 .article tr,
body.page-id-13 .article th,
body.page-id-13 .article td,
body.page-id-13 .article table.himiko-tokusho-table,
body.page-id-13 .article table.himiko-tokusho-table thead,
body.page-id-13 .article table.himiko-tokusho-table tbody,
body.page-id-13 .article table.himiko-tokusho-table tr,
body.page-id-13 .article table.himiko-tokusho-table th,
body.page-id-13 .article table.himiko-tokusho-table td {
  display: revert !important;
}

body.page-id-13 .article table,
body.page-id-13 .article table.himiko-tokusho-table {
  width: 100% !important;
  max-width: 100% !important;
  table-layout: fixed !important;
  border-collapse: collapse !important;
  border: none !important;
  outline: none !important;
  box-shadow: none !important;
  background: transparent !important;
  margin: 1.5rem 0 !important;
}

body.page-id-13 .article th,
body.page-id-13 .article table.himiko-tokusho-table th {
  width: 32% !important;
  padding: 12px 14px !important;
  background: rgba(45, 38, 22, 0.92) !important;
  color: #d4af6e !important;
  border: none !important;
  box-shadow: none !important;
  font-weight: 600 !important;
  text-align: left !important;
  vertical-align: top !important;
  white-space: normal !important;
}

body.page-id-13 .article td,
body.page-id-13 .article table.himiko-tokusho-table td {
  padding: 12px 14px !important;
  background: rgba(16, 16, 34, 0.92) !important;
  color: rgba(230, 225, 215, 0.92) !important;
  border: none !important;
  box-shadow: none !important;
  text-align: left !important;
  vertical-align: top !important;
  white-space: normal !important;
  word-break: break-word !important;
  overflow-wrap: anywhere !important;
}

body.page-id-13 .article table.himiko-tokusho-table,
body.page-id-13 .article table,
.article table.himiko-tokusho-table,
table.himiko-tokusho-table {
  border: none !important;
}

body.page-id-13 .article table,
body.page-id-13 .article table.himiko-tokusho-table,
body.page-id-13 .article table thead,
body.page-id-13 .article table tbody,
body.page-id-13 .article table tr,
body.page-id-13 .article table th,
body.page-id-13 .article table td,
body.page-id-13 .article table.himiko-tokusho-table thead,
body.page-id-13 .article table.himiko-tokusho-table tbody,
body.page-id-13 .article table.himiko-tokusho-table tr,
body.page-id-13 .article table.himiko-tokusho-table th,
body.page-id-13 .article table.himiko-tokusho-table td {
  border: none !important;
  box-shadow: none !important;
}

body.page-id-13 .article .scroll-table,
body.page-id-13 .article .wp-block-table,
body.page-id-13 .article figure.wp-block-table {
  width: 100% !important;
  max-width: 100% !important;
  overflow-x: auto !important;
}

/* =========================================================
   14. 共有系の軽量整理
   ========================================================= */
.entry-date,
.post-date,
.post-update,
.eye-catch,
.author-info,
.entry-categories-tags,
.footer-author-box,
.sns-follow,
.sns-follow-buttons {
  display: none !important;
}

.sns-share,
.sns-share-buttons {
  opacity: 0.5;
  transform: scale(0.85);
  transition: opacity 0.3s;
  margin: 1rem auto !important;
}

.sns-share:hover,
.sns-share-buttons:hover {
  opacity: 0.9;
}

.sns-share-message {
  color: #8a8070 !important;
  font-size: 0.85rem !important;
}

.sns-share.ss-bottom .sns-share-buttons {
  display: none !important;
}

.himiko-blur-content,
.himiko-result-blurred {
  min-height: 100px;
}

/* =========================================================
   15. レスポンシブ
   ========================================================= */
@media screen and (max-width: 1023px) {
  :root {
    --hm-content-width: 100%;
  }

  .header .header-in.wrap {
    padding-left: 18px !important;
    padding-right: 18px !important;
  }

  body.page-id-8 .main,
  body.page-id-9 .main,
  body.page-id-10 .main,
  body.single-ranking .main,
  body.page-id-126 .main {
    padding-top: 32px !important;
  }

  #post-8.article,
  #post-9.article,
  #post-10.article,
  body.single-ranking article,
  body.page-id-3 .article,
  body.page-id-11 .article,
  body.page-id-13 .article,
  body.page-id-48 .article,
  body.page-id-126 .article {
    padding: 2.5rem 1rem !important;
  }

  body.page-id-8 .main,
  body.page-id-9 .main,
  body.page-id-10 .main,
  body.single-ranking .main,
  body.page-id-3 .main,
  body.page-id-11 .main,
  body.page-id-13 .main,
  body.page-id-48 .main,
  body.page-id-126 .main {
    padding-left: 0 !important;
    padding-right: 0 !important;
  }

  body.page-id-8 .entry-title,
  body.page-id-9 .entry-title,
  body.page-id-10 .entry-title,
  body.single-ranking h1,
  body.page-id-3 .article .entry-title,
  body.page-id-11 .article .entry-title,
  body.page-id-13 .article .entry-title,
  body.page-id-48 .article .entry-title,
  body.page-id-126 .article .entry-title {
    font-size: 24px !important;
  }

  .himiko-premium-section {
    border-radius: 12px;
    padding: 48px 16px 40px !important;
    margin: 12px 12px !important;
    width: calc(100% - 24px) !important;
    max-width: calc(100% - 24px) !important;
  }

  .himiko-premium-features {
    grid-template-columns: 1fr;
    max-width: 320px;
  }

  body.page-id-10 figure.wp-block-image.himiko-premium-hero-img,
  body.page-id-10 figure.wp-block-image.aligncenter.himiko-premium-hero-img {
    max-width: 300px !important;
  }

  body.page-id-10 .himiko-premium-features {
    margin-top: -56px !important;
    padding-top: 40px !important;
  }

  body.page-id-8 .entry-content form {
    padding: 36px 24px 32px;
  }

  .himiko-ranking-full {
    padding: 24px 16px;
  }

  .himiko-ranking-entry {
    grid-template-columns: 56px 1fr auto !important;
    padding: 16px 12px;
  }

  .himiko-premium-pricing {
    padding: 32px 20px;
  }

  .himiko-premium-pricing .sale-price {
    font-size: 34px;
  }

  .himiko-result-free {
    padding: 0 20px 32px;
  }

  .himiko-scores-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 10px;
  }

  .himiko-score-total .score {
    font-size: 52px;
  }
}

@media screen and (max-width: 834px) {
  .himiko-global-bg__overlay {
    background: linear-gradient(
      180deg,
      rgba(6, 6, 18, 0.84) 0%,
      rgba(8, 8, 22, 0.78) 40%,
      rgba(6, 6, 18, 0.86) 100%
    );
  }

  .himiko-hero {
    padding: 60px 16px 48px;
  }

  body.page-id-27 .himiko-premium-section .himiko-premium-visual {
    max-width: 55% !important;
    opacity: 0.24;
    -webkit-mask-image: linear-gradient(to left, rgba(0, 0, 0, 1) 0%, rgba(0, 0, 0, 1) 45%, rgba(0, 0, 0, 0.45) 75%, rgba(0, 0, 0, 0) 100%) !important;
            mask-image: linear-gradient(to left, rgba(0, 0, 0, 1) 0%, rgba(0, 0, 0, 1) 45%, rgba(0, 0, 0, 0.45) 75%, rgba(0, 0, 0, 0) 100%) !important;
  }

  .himiko-legal-bar {
    margin: 18px auto 10px !important;
    padding: 12px 12px !important;
  }
}

@media screen and (max-width: 600px) {
  body.page-id-27 .himiko-hero-title,
  body.page-id-27 .article h2.himiko-hero-title,
  body.page-id-27 .entry-content h2.himiko-hero-title,
  body.page-id-27 h2.himiko-hero-title {
    font-size: 22px !important;
  }

  .himiko-nav-grid {
    gap: 10px;
  }

  .himiko-nav-card,
  a.himiko-nav-card {
    padding: 20px 8px;
  }

  .himiko-nav-icon {
    font-size: 24px;
  }

  .himiko-nav-label {
    font-size: 11px;
  }
}

@media screen and (max-width: 480px) {
  .himiko-global-bg__overlay {
    background: linear-gradient(
      180deg,
      rgba(6, 6, 18, 0.88) 0%,
      rgba(8, 8, 22, 0.82) 40%,
      rgba(6, 6, 18, 0.90) 100%
    );
  }

  .header .header-in.wrap {
    padding-left: 14px !important;
    padding-right: 14px !important;
  }

  .himiko-hero {
    padding: 48px 14px 40px;
  }

  .himiko-premium-section {
    border-radius: 10px;
    padding: 40px 14px 36px !important;
    margin: 10px 8px !important;
    width: calc(100% - 16px) !important;
    max-width: calc(100% - 16px) !important;
  }

  body.page-id-27 .himiko-hero .himiko-hero-img,
  body.page-id-27 img.himiko-hero-img {
    width: 240px !important;
    margin: 18px auto 22px !important;
  }

  body.page-id-27 .himiko-premium-section .himiko-premium-visual {
    max-width: 65% !important;
    opacity: 0.18;
    -webkit-mask-image: linear-gradient(to left, rgba(0, 0, 0, 1) 0%, rgba(0, 0, 0, 1) 40%, rgba(0, 0, 0, 0.35) 75%, rgba(0, 0, 0, 0) 100%) !important;
            mask-image: linear-gradient(to left, rgba(0, 0, 0, 1) 0%, rgba(0, 0, 0, 1) 40%, rgba(0, 0, 0, 0.35) 75%, rgba(0, 0, 0, 0) 100%) !important;
  }

  body.page-id-8 .main,
  body.page-id-9 .main,
  body.page-id-10 .main,
  body.single-ranking .main,
  body.page-id-126 .main {
    padding-top: 32px !important;
  }

  body.page-id-8 .entry-content form {
    padding: 28px 14px 24px !important;
    margin: 24px 0 !important;
  }

  body.page-id-8 .entry-content form::before,
  body.page-id-8 .entry-content form::after {
    width: 20px;
    height: 20px;
  }

  body.page-id-8 .entry-content button[type="submit"],
  body.page-id-8 .entry-content input[type="submit"],
  body.page-id-8 .himiko-btn-primary,
  body.page-id-8 a.himiko-btn-primary,
  body.page-id-8 button.himiko-btn-primary,
  body.page-id-8 input.himiko-btn-primary {
    width: 310px !important;
    max-width: 100% !important;
    padding: 14px 20px !important;
  }

  .himiko-ranking-entry {
    grid-template-columns: 52px 1fr !important;
    gap: 0 10px;
  }

  .himiko-ranking-entry .rank,
  .himiko-ranking-entry .rank-no,
  .himiko-ranking-entry > span:first-child {
    min-width: 52px !important;
    width: 52px !important;
  }

  .himiko-ranking-entry .score {
    grid-column: 2;
    grid-row: auto;
    text-align: left;
    font-size: 16px;
    margin-top: 4px;
  }

  .himiko-result-free {
    padding: 0 16px 24px;
  }

  .himiko-scores-grid {
    grid-template-columns: 1fr 1fr;
    gap: 8px;
  }

  .himiko-score-total .score {
    font-size: 44px;
  }

  .himiko-cta-overlay {
    padding: 36px 16px 32px;
  }

  .himiko-cta-price .sale-price {
    font-size: 24px;
  }

  .himiko-premium-pricing .sale-price {
    font-size: 28px;
  }

  .himiko-share {
    flex-direction: column;
    align-items: center;
  }

  body.page-id-10 figure.wp-block-image.himiko-premium-hero-img,
  body.page-id-10 figure.wp-block-image.aligncenter.himiko-premium-hero-img {
    max-width: 260px !important;
    margin-top: 20px !important;
  }

  body.page-id-10 .himiko-premium-features {
    margin-top: -40px !important;
    padding-top: 32px !important;
  }

  body.page-id-13 .article table th,
  body.page-id-13 .article table td,
  body.page-id-13 .article table.himiko-tokusho-table th,
  body.page-id-13 .article table.himiko-tokusho-table td {
    padding: 10px 12px !important;
    font-size: 14px !important;
  }

  .himiko-legal-bar {
    font-size: 12px;
    letter-spacing: 0.02em;
  }

  .himiko-legal-bar a {
    padding: 0 5px;
  }
}

/* ホーム左寄せ修正 */
body.page-id-27 #content,
body.page-id-27 .content,
body.page-id-27 #content-in,
body.page-id-27 .content-in,
body.page-id-27 #main,
body.page-id-27 .main,
body.page-id-27 .article,
body.page-id-27 .entry-content {
  display: block !important;
  width: 100% !important;
  max-width: 100% !important;
  float: none !important;
  margin-left: auto !important;
  margin-right: auto !important;
  left: auto !important;
  right: auto !important;
  padding-left: 0 !important;
  padding-right: 0 !important;
}

body.page-id-27 .content,
body.page-id-27 #content {
  justify-content: center !important;
  align-items: stretch !important;
}

/* =========================================================
   2026-04-15 追加修正
   - result ページの有料CTA崩れ修正
   - result ページのシェアボタン修正
   - トップの premium 背景画像をスマホで少し右へ
   ========================================================= */

/* =========================
   1) result ページの修正
   ========================= */

/* PC / 共通：CTAカードをちゃんと中央のカードとして見せる */
body.page-id-9 .himiko-result-paid--locked .himiko-blur-overlay {
  padding: 28px 24px 110px !important;
  opacity: 0.22 !important;
  filter: blur(1px) !important;
  -webkit-filter: blur(1px) !important;
}

body.page-id-9 .himiko-cta-overlay {
  position: relative !important;
  z-index: 2 !important;
  width: min(100%, 420px) !important;
  margin: -88px 0 0 !important;
  padding: 28px 24px 24px !important;
  border-radius: 16px !important;
}

body.page-id-9 .himiko-cta-text {
  font-size: 22px !important;
  line-height: 1.5 !important;
  letter-spacing: 0.04em !important;
}

body.page-id-9 .himiko-cta-price {
  display: flex !important;
  justify-content: center !important;
  align-items: flex-end !important;
  gap: 12px !important;
  flex-wrap: wrap !important;
  margin-bottom: 20px !important;
}

body.page-id-9 .himiko-cta-price .original-price {
  margin-right: 0 !important;
}

body.page-id-9 .himiko-cta-price .sale-price {
  font-size: 32px !important;
  line-height: 1 !important;
}

body.page-id-9 .himiko-cta-overlay .himiko-btn-primary,
body.page-id-9 .himiko-cta-overlay a.himiko-btn-primary {
  display: inline-flex !important;
  justify-content: center !important;
  align-items: center !important;
  width: auto !important;
  min-width: 220px !important;
  max-width: none !important;
  padding: 16px 32px !important;
  white-space: nowrap !important;
  line-height: 1.2 !important;
  border-radius: 24px !important;
  font-size: 18px !important;
  letter-spacing: 0.08em !important;
  writing-mode: horizontal-tb !important;
}

/* シェアボタン：横並び・中央揃え・角丸少し小さめ */
body.page-id-9 .himiko-share {
  display: flex !important;
  flex-direction: row !important;
  justify-content: center !important;
  align-items: center !important;
  gap: 12px !important;
}

body.page-id-9 .himiko-share-btn {
  display: inline-flex !important;
  justify-content: center !important;
  align-items: center !important;
  text-align: center !important;
  min-width: 150px !important;
  padding: 10px 16px !important;
  border-radius: 6px !important;
}

/* スマホだけ追加調整 */
@media screen and (max-width: 480px) {
  body.page-id-9 .himiko-result-paid--locked .himiko-blur-overlay {
    padding: 22px 14px 92px !important;
  }

  body.page-id-9 .himiko-cta-overlay {
    width: calc(100% - 24px) !important;
    margin: -68px 0 0 !important;
    padding: 22px 18px 20px !important;
    border-radius: 14px !important;
  }

  body.page-id-9 .himiko-cta-text {
    font-size: 20px !important;
    line-height: 1.45 !important;
  }

  body.page-id-9 .himiko-cta-price {
    gap: 8px !important;
    margin-bottom: 18px !important;
  }

  body.page-id-9 .himiko-cta-price .sale-price {
    font-size: 28px !important;
  }

  body.page-id-9 .himiko-cta-overlay .himiko-btn-primary,
  body.page-id-9 .himiko-cta-overlay a.himiko-btn-primary {
    min-width: 200px !important;
    width: auto !important;
    max-width: 100% !important;
    padding: 14px 26px !important;
    font-size: 18px !important;
    border-radius: 50px !important;
    white-space: nowrap !important;
    writing-mode: horizontal-tb !important;
  }

  body.page-id-9 .himiko-share {
    flex-direction: row !important;
    gap: 10px !important;
  }

  body.page-id-9 .himiko-share-btn {
    min-width: 136px !important;
    padding: 10px 14px !important;
    border-radius: 6px !important;
  }

  body.page-id-13 .himiko-tokusho-table,
  body.page-id-13 .himiko-tokusho-table tbody,
  body.page-id-13 .himiko-tokusho-table tr,
  body.page-id-13 .himiko-tokusho-table th,
  body.page-id-13 .himiko-tokusho-table td {
    border: none !important;
  }
}

/* =========================
   2) トップ premium 背景画像
   スマホで少し右にずらす
   ========================= */
@media screen and (max-width: 480px) {
  body.page-id-27 .himiko-premium-section .himiko-premium-visual {
    right: -10px !important;
    max-width: 68% !important;
    object-position: 50% center !important;
  }
}

/* ─── 23. 購入済み結果ページ：ダーク高級スタイル ─── */
/* 世界観（濃紺 + 金 + 高級感）を維持しつつ可読性を確保。
   対象：.himiko-result-paid--unlocked 配下のみ。他ページ波及なし。 */

/* --- 23-1. セクション見出し（PREMIUM CONTENT / 年間運勢 完全版） --- */
body .article .himiko-result-paid--unlocked .himiko-paid-label,
body .entry-content .himiko-result-paid--unlocked .himiko-paid-label {
    display: block !important;
    font-family: 'Cinzel Decorative', 'Cinzel', serif !important;
    font-size: 11px !important;
    letter-spacing: 0.2em !important;
    color: rgba(212, 175, 55, 0.7) !important;
    text-transform: uppercase;
    margin: 8px 0 6px !important;
    padding: 0 !important;
    opacity: 1 !important;
    text-align: center !important;
}
body .article .himiko-result-paid--unlocked .himiko-paid-heading,
body .entry-content .himiko-result-paid--unlocked .himiko-paid-heading {
    font-size: 22px !important;
    font-weight: 700 !important;
    color: #F3D98C !important;
    margin: 0 0 28px !important;
    padding: 0 !important;
    border: none !important;
    background: none !important;
    opacity: 1 !important;
    text-align: center !important;
}

/* --- 23-2. 月別カード（.himiko-month-item） --- */
body .article .himiko-result-paid--unlocked .himiko-month-item,
body .entry-content .himiko-result-paid--unlocked .himiko-month-item {
    background: rgba(10, 16, 34, 0.88) !important;
    border: 1px solid rgba(212, 175, 55, 0.28) !important;
    border-radius: 10px !important;
    padding: 20px 18px !important;
    margin-bottom: 18px !important;
}

/* 月名 strong */
body .article .himiko-result-paid--unlocked .himiko-month-item strong,
body .entry-content .himiko-result-paid--unlocked .himiko-month-item strong {
    display: block !important;
    text-align: center !important;
    color: #F3D98C !important;
    font-size: 17px !important;
    font-weight: 600 !important;
    line-height: 1.4 !important;
    opacity: 1 !important;
    margin: 0 0 12px !important;
    padding: 0 0 10px !important;
    border-bottom: 1px solid rgba(212, 175, 55, 0.18) !important;
}

/* 月別カード本文 p */
body .article .himiko-result-paid--unlocked .himiko-month-item p,
body .entry-content .himiko-result-paid--unlocked .himiko-month-item p {
    color: #EDEAD0 !important;
    opacity: 1 !important;
    font-size: 14px !important;
    line-height: 1.95 !important;
    letter-spacing: 0.015em !important;
    margin-top: 12px !important;
}

/* 補足テキスト（.action, .lucky） */
body .article .himiko-result-paid--unlocked .action,
body .entry-content .himiko-result-paid--unlocked .action,
body .article .himiko-result-paid--unlocked .lucky,
body .entry-content .himiko-result-paid--unlocked .lucky {
    color: #B9B2A0 !important;
    font-size: 12.5px !important;
    line-height: 1.75 !important;
    opacity: 1 !important;
}

/* --- 23-3. 月別詳細運勢 見出し h4 --- */
body .article .himiko-result-paid--unlocked .himiko-monthly-detail > h4,
body .entry-content .himiko-result-paid--unlocked .himiko-monthly-detail > h4 {
    color: #F3D98C !important;
    font-size: 18px !important;
    font-weight: 700 !important;
    margin-bottom: 20px !important;
    opacity: 1 !important;
    text-align: center !important;
}

/* --- 23-4. 下部解説セクション（.himiko-detail-section） --- */
/* 恋愛運詳細 / 仕事・金運詳細 / 年間総評 */
body .article .himiko-result-paid--unlocked .himiko-detail-section,
body .entry-content .himiko-result-paid--unlocked .himiko-detail-section {
    background: rgba(10, 16, 34, 0.72) !important;
    border: 1px solid rgba(212, 175, 55, 0.2) !important;
    border-radius: 10px !important;
    padding: 20px 22px !important;
    margin-bottom: 20px !important;
}
body .article .himiko-result-paid--unlocked .himiko-detail-section h4,
body .entry-content .himiko-result-paid--unlocked .himiko-detail-section h4 {
    color: #F3D98C !important;
    font-size: 18px !important;
    font-weight: 700 !important;
    margin-bottom: 14px !important;
    padding-bottom: 10px !important;
    border-bottom: 1px solid rgba(212, 175, 55, 0.18) !important;
    opacity: 1 !important;
    text-align: center !important;
}
body .article .himiko-result-paid--unlocked .himiko-detail-section p,
body .entry-content .himiko-result-paid--unlocked .himiko-detail-section p {
    color: #E8E4D8 !important;
    opacity: 1 !important;
    line-height: 1.85;
    font-size: 15px !important;
}

/* --- 23-5. セクション見出しの罫線調整（Cocoon既定の長い白横線を無効化し、金系の短い中央アクセントに置換） --- */
/* 対象: 月別詳細運勢 / 恋愛運 詳細アドバイス / 仕事・金運 詳細アドバイス / 年間の総評 */
body .article .himiko-result-paid--unlocked .himiko-monthly-detail > h4,
body .article .himiko-result-paid--unlocked .himiko-detail-section h4,
body .entry-content .himiko-result-paid--unlocked .himiko-monthly-detail > h4,
body .entry-content .himiko-result-paid--unlocked .himiko-detail-section h4 {
    border-top: none !important;
    border-bottom: none !important;
    background: none !important;
    padding-top: 0 !important;
    padding-bottom: 0 !important;
    margin-top: 4px !important;
    margin-bottom: 18px !important;
    position: relative !important;
}
/* Cocoon 既定の ::before 装飾（長い横線）を無効化 */
body .article .himiko-result-paid--unlocked .himiko-monthly-detail > h4::before,
body .article .himiko-result-paid--unlocked .himiko-detail-section h4::before,
body .entry-content .himiko-result-paid--unlocked .himiko-monthly-detail > h4::before,
body .entry-content .himiko-result-paid--unlocked .himiko-detail-section h4::before {
    display: none !important;
    content: none !important;
    background: none !important;
    border: none !important;
}
/* 金系の短い中央アクセント（見出し直下に 44px の低コントラストな金グラデーション） */
body .article .himiko-result-paid--unlocked .himiko-monthly-detail > h4::after,
body .article .himiko-result-paid--unlocked .himiko-detail-section h4::after,
body .entry-content .himiko-result-paid--unlocked .himiko-monthly-detail > h4::after,
body .entry-content .himiko-result-paid--unlocked .himiko-detail-section h4::after {
    content: '' !important;
    display: block !important;
    width: 44px !important;
    height: 1px !important;
    margin: 10px auto 0 !important;
    background: linear-gradient(90deg, transparent, rgba(212, 175, 55, 0.5), transparent) !important;
    border: none !important;
    position: static !important;
}

/* PC以外で改行 */

br.u-br-sp { display: none; }
br.u-br-pc { display: revert; }
.u-nowrap { white-space: nowrap; }

@media screen and (max-width: 767px) {
  br.u-br-sp { display: revert; }
  br.u-br-pc { display: none; }
}


/* =========================================================
   26. ランキングページ見出し余白の /terms/ 基準合わせ
   - single-ranking はテンプレート側で .himiko-ranking-page / .himiko-ranking-header / h1 を
     独自出力しているため、logo 下余白が他ページとズレやすい。
   - /terms/ と同じ見え方になるよう、ランキングだけ top padding を打ち消し、
     見出しの上マージンを統一する。
   ========================================================= */
body.single-ranking .himiko-ranking-page {
  padding-top: 0 !important;
}

body.single-ranking .himiko-ranking-header {
  margin: 0 0 24px !important;
  padding: 0 !important;
}

body.single-ranking .himiko-ranking-header h1 {
  margin: 16px 0 24px !important;
  padding: 0 0 16px !important;
  font-family: var(--hm-font-display-ja) !important;
  font-size: 28px !important;
  font-weight: 600 !important;
  line-height: 1.4 !important;
  letter-spacing: 0.06em !important;
  color: var(--hm-text-gold) !important;
  text-align: center !important;
  background: transparent !important;
  border: none !important;
  border-bottom: 1px solid var(--hm-border-gold) !important;
  text-shadow: 0 0 24px rgba(191, 155, 84, 0.15) !important;
}

@media screen and (max-width: 1023px) {
  body.single-ranking .himiko-ranking-page {
    padding-top: 0 !important;
  }

  body.single-ranking .himiko-ranking-header {
    margin: 0 0 24px !important;
  }

  body.single-ranking .himiko-ranking-header h1 {
    font-size: 24px !important;
    margin: 16px 0 24px !important;
    padding-bottom: 16px !important;
  }
}

@media screen and (max-width: 480px) {
  body.single-ranking .himiko-ranking-page {
    padding-top: 0 !important;
  }

  body.single-ranking .himiko-ranking-header {
    margin: 0 0 24px !important;
  }

  body.single-ranking .himiko-ranking-header h1 {
    font-size: 24px !important;
    margin: 16px 0 24px !important;
    padding-bottom: 16px !important;
  }
}

/* =========================================
   AI卑弥呼：トップへ戻るボタンのデザイン調整
   ========================================= */

#go-to-top,
.go-to-top,
.go-to-top-button,
a.go-to-top-button,
button.go-to-top-button {
    background: linear-gradient(180deg, #EBC878 0%, #C9A343 100%) !important;
    background-color: #D4A843 !important;
    color: #12172a !important;
    border: 1px solid rgba(243, 217, 140, 0.55) !important;
    box-shadow:
        0 0 18px rgba(212, 175, 55, 0.22),
        0 4px 12px rgba(0, 0, 0, 0.35) !important;
}

#go-to-top:hover,
.go-to-top:hover,
.go-to-top-button:hover,
a.go-to-top-button:hover,
button.go-to-top-button:hover {
    filter: brightness(1.08) !important;
    opacity: 1 !important;
}

#go-to-top *,
.go-to-top *,
.go-to-top-button *,
a.go-to-top-button *,
button.go-to-top-button * {
    color: #12172a !important;
}

/* トップページ：年間運勢 完全版の収録内容を6項目に更新 */
.himiko-premium-features--updated {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
  max-width: 560px;
  margin: 0 auto 32px;
}

.himiko-premium-features--updated .himiko-feature-item {
  min-height: 96px;
}

@media screen and (max-width: 600px) {
  .himiko-premium-features--updated {
    grid-template-columns: repeat(2, 1fr);
    gap: 10px;
    max-width: 360px;
  }

  .himiko-premium-features--updated .himiko-feature-item {
    min-height: 88px;
  }
}
