/*
Theme Name: Fortune Oracle
Theme URI: https://fortune-tool-lab.com/
Description: 占いツール制作ラボ専用テーマ。タロット・四柱推命・数秘術をテーマにしたダーク神秘系デザイン。
Author: 占いツール制作ラボ
Author URI: https://fortune-tool-lab.com/
Version: 1.0.0
License: GNU General Public License v2 or later
Text Domain: fortune-oracle
Tags: dark, mystical, fortune-telling, japanese
*/

/* =============================================
   CSS変数
============================================= */
:root {
  --bg-deep:   #0b0916;
  --bg-dark:   #120f1e;
  --bg-mid:    #1c1630;
  --bg-card:   #221942;
  --purple:    #7b52ab;
  --purple-lt: #9b6fd4;
  --gold:      #c9a04a;
  --gold-lt:   #e8d5a0;
  --gold-dim:  rgba(201,160,74,.35);
  --text:      #f0e6d3;
  --text-dim:  #b8a9d0;
  --radius:    12px;
  --radius-lg: 20px;
}

/* =============================================
   リセット & ベース
============================================= */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; font-size: 16px; }
body {
  background: var(--bg-deep);
  color: var(--text);
  font-family: -apple-system, BlinkMacSystemFont, "Hiragino Kaku Gothic ProN", "Yu Gothic", Meiryo, sans-serif;
  line-height: 1.75;
  overflow-x: hidden;
}
a { color: var(--gold-lt); text-decoration: none; transition: color .2s; }
a:hover { color: var(--gold); }
img { max-width: 100%; height: auto; display: block; }
ul, ol { padding-left: 1.5em; }
button { cursor: pointer; border: none; font-family: inherit; background: none; }
h1,h2,h3,h4,h5,h6 { line-height: 1.3; color: var(--text); }
p { color: var(--text); }

/* =============================================
   星空背景
============================================= */
.stars-bg {
  position: fixed; inset: 0; pointer-events: none; z-index: 0;
  background:
    radial-gradient(ellipse at 20% 10%, rgba(123,82,171,.18) 0%, transparent 50%),
    radial-gradient(ellipse at 80% 20%, rgba(90,50,140,.15) 0%, transparent 45%),
    linear-gradient(180deg, #0b0916 0%, #13102a 50%, #0b0916 100%);
}
.stars-bg::before, .stars-bg::after {
  content: ''; position: absolute; inset: 0;
  background-image:
    radial-gradient(1px 1px at 10% 15%, rgba(255,255,255,.8) 0%, transparent 100%),
    radial-gradient(1px 1px at 25% 40%, rgba(255,255,255,.6) 0%, transparent 100%),
    radial-gradient(1.5px 1.5px at 40%  8%, rgba(255,255,255,.9) 0%, transparent 100%),
    radial-gradient(1px 1px at 55% 55%, rgba(255,255,255,.5) 0%, transparent 100%),
    radial-gradient(1px 1px at 70% 22%, rgba(255,255,255,.7) 0%, transparent 100%),
    radial-gradient(1.5px 1.5px at 85% 45%, rgba(255,255,255,.8) 0%, transparent 100%),
    radial-gradient(1px 1px at 15% 65%, rgba(255,255,255,.6) 0%, transparent 100%),
    radial-gradient(1.5px 1.5px at 48% 32%, rgba(201,160,74,.4) 0%, transparent 100%),
    radial-gradient(1px 1px at 78% 75%, rgba(255,255,255,.6) 0%, transparent 100%),
    radial-gradient(1px 1px at 90% 10%, rgba(255,255,255,.8) 0%, transparent 100%);
  animation: twinkle 4s ease-in-out infinite alternate;
}
.stars-bg::after {
  background-image:
    radial-gradient(1px 1px at 18% 25%, rgba(255,255,255,.7) 0%, transparent 100%),
    radial-gradient(1.5px 1.5px at 62% 48%, rgba(255,255,255,.8) 0%, transparent 100%),
    radial-gradient(1px 1px at 75% 35%, rgba(255,255,255,.6) 0%, transparent 100%),
    radial-gradient(1.5px 1.5px at  8% 38%, rgba(201,160,74,.35) 0%, transparent 100%),
    radial-gradient(1px 1px at 52% 18%, rgba(255,255,255,.6) 0%, transparent 100%),
    radial-gradient(1px 1px at 33% 78%, rgba(255,255,255,.5) 0%, transparent 100%);
  animation: twinkle 5s ease-in-out 2s infinite alternate;
}
@keyframes twinkle { 0%{opacity:.6} 100%{opacity:1} }

/* =============================================
   レイアウト
============================================= */
.site-wrapper { position: relative; z-index: 1; min-height: 100vh; display: flex; flex-direction: column; }
.container { max-width: 1100px; margin: 0 auto; padding: 0 20px; }
.content-area { max-width: 780px; margin: 0 auto; padding: 0 20px; }
.page-section { padding: 70px 0; }
.sep { height: 1px; background: linear-gradient(90deg, transparent, rgba(123,82,171,.2), transparent); }

.section-title {
  text-align: center; font-size: clamp(20px,3vw,26px); font-weight: 800;
  margin-bottom: 40px; color: var(--text);
  display: flex; align-items: center; justify-content: center; gap: 12px;
}
.section-title::before { content:''; flex:1; max-width:60px; height:1px; background:linear-gradient(90deg,transparent,var(--gold)); }
.section-title::after  { content:''; flex:1; max-width:60px; height:1px; background:linear-gradient(90deg,var(--gold),transparent); }

/* =============================================
   ボタン
============================================= */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 8px;
  padding: 12px 24px; border-radius: 999px;
  font-size: 14px; font-weight: 700; letter-spacing: .06em;
  transition: transform .2s, box-shadow .2s; cursor: pointer; text-decoration: none;
}
.btn:hover { transform: translateY(-2px); box-shadow: 0 8px 30px rgba(0,0,0,.4); }
.btn-gold    { background: linear-gradient(135deg,#c9a04a,#e8c96a,#b8882a); color: #2a1a00 !important; }
.btn-outline { background: transparent; border: 1.5px solid rgba(201,160,74,.6); color: var(--gold-lt) !important; }
.btn-outline:hover { background: rgba(201,160,74,.1); color: var(--gold-lt) !important; }
.btn-purple  { background: linear-gradient(135deg,#7b52ab,#9b6fd4); color: white !important; }
.btn-aura    { background: linear-gradient(135deg,#9b72cb,#c678ff,#c9a04a); color: white !important; }
.btn-lg      { font-size: 16px; padding: 16px 36px; }

/* =============================================
   カード
============================================= */
.card {
  background: linear-gradient(145deg, rgba(34,25,66,.9), rgba(28,22,55,.95));
  border: 1px solid rgba(201,160,74,.2);
  border-radius: var(--radius);
  transition: transform .25s, border-color .25s, box-shadow .25s;
}
.card:hover {
  transform: translateY(-4px);
  border-color: rgba(201,160,74,.5);
  box-shadow: 0 12px 40px rgba(0,0,0,.5), 0 0 20px rgba(123,82,171,.2);
}

/* =============================================
   ヘッダー
============================================= */
.site-header {
  position: sticky; top: 0; z-index: 100;
  background: rgba(11,9,22,.88);
  backdrop-filter: blur(14px);
  border-bottom: 1px solid rgba(201,160,74,.15);
}
.header-inner {
  display: flex; align-items: center; justify-content: space-between;
  padding: 14px 20px; max-width: 1100px; margin: 0 auto;
}
.site-logo { display: flex; align-items: center; gap: 10px; text-decoration: none; }
.logo-icon  { width:36px; height:36px; background:linear-gradient(135deg,#7b52ab,#c9a04a); border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:18px; flex-shrink:0; }
.logo-name  { font-size:15px; font-weight:800; color:var(--gold-lt); letter-spacing:.04em; line-height:1.2; }
.logo-sub   { font-size:10px; color:var(--text-dim); letter-spacing:.08em; }
.site-nav   { display:flex; align-items:center; gap:22px; }
.nav-links  { display:flex; align-items:center; gap:22px; }
.nav-links a { font-size:13px; font-weight:600; color:var(--text-dim); border-bottom:1.5px solid transparent; padding:4px 0; transition:color .2s,border-color .2s; }
.nav-links a:hover { color:var(--gold-lt); border-color:var(--gold); }
.nav-search { font-size:16px; color:var(--text-dim); cursor:pointer; transition:color .2s; background:none; border:none; padding:4px; }
.nav-search:hover { color:var(--gold); }
.hamburger  { display:none; flex-direction:column; gap:5px; cursor:pointer; }
.hamburger span { width:22px; height:2px; background:var(--gold-lt); border-radius:2px; display:block; }
/* モバイルメニュー */
.mobile-menu {
  display: none; position: fixed; top: 64px; left: 0; right: 0;
  background: rgba(11,9,22,.97); border-bottom:1px solid rgba(201,160,74,.15);
  z-index: 99; padding: 20px;
}
.mobile-menu.open { display: block; }
.mobile-menu a { display:block; padding:12px 0; border-bottom:1px solid rgba(201,160,74,.1); color:var(--text-dim); font-size:15px; }
.mobile-menu a:last-child { border-bottom:none; }

/* =============================================
   フッター
============================================= */
.site-footer { background:#07050f; border-top:1px solid rgba(201,160,74,.12); padding:60px 0 30px; margin-top:auto; }
.footer-inner { display:grid; grid-template-columns:2fr 1fr 1fr 1fr; gap:40px; max-width:1100px; margin:0 auto 40px; padding:0 20px; }
.footer-brand p { font-size:13px; color:var(--text-dim); margin-top:14px; line-height:1.7; }
.footer-col-title { font-size:13px; font-weight:800; color:var(--gold-lt); margin-bottom:14px; }
.footer-col ul  { list-style:none; padding:0; }
.footer-col li  { margin-bottom:10px; }
.footer-col a   { font-size:13px; color:var(--text-dim); }
.footer-col a:hover { color:var(--gold-lt); }
.footer-social  { display:flex; gap:12px; margin-top:18px; }
.social-btn { width:36px; height:36px; border-radius:50%; background:rgba(255,255,255,.08); border:1px solid rgba(255,255,255,.12); display:flex; align-items:center; justify-content:center; font-size:15px; transition:background .2s; }
.social-btn:hover { background:rgba(201,160,74,.2); }
.footer-ranking { text-align:center; padding:20px 20px 0; max-width:1100px; margin:0 auto; }
.footer-ranking-label { font-size:11px; color:var(--text-dim); letter-spacing:.08em; margin-bottom:10px; }
.footer-ranking-banners { display:flex; justify-content:center; align-items:center; flex-wrap:wrap; gap:12px; }
.footer-ranking-banners a img { height:36px; width:auto; opacity:.8; transition:opacity .2s; border-radius:4px; }
.footer-ranking-banners a:hover img { opacity:1; }
.footer-bottom { border-top:1px solid rgba(255,255,255,.06); padding-top:22px; text-align:center; max-width:1100px; margin:0 auto; padding-left:20px; padding-right:20px; }
.footer-bottom p { font-size:12px; color:var(--text-dim); }
.footer-bottom-links { display:flex; justify-content:center; gap:20px; margin-top:8px; }
.footer-bottom-links a { font-size:12px; color:var(--text-dim); }

/* =============================================
   フロントページ
============================================= */
/* ヒーロー */
.hero { min-height:88vh; display:flex; align-items:center; position:relative; overflow:hidden; padding:80px 0 60px; }
.hero::before { content:''; position:absolute; inset:0; background:radial-gradient(ellipse at 70% 50%,rgba(123,82,171,.25) 0%,transparent 55%),radial-gradient(ellipse at 20% 50%,rgba(60,30,100,.2) 0%,transparent 50%); }
.hero-inner { display:grid; grid-template-columns:1fr 1fr; gap:40px; align-items:center; position:relative; z-index:1; }
.hero-badge { display:inline-block; background:rgba(201,160,74,.15); border:1px solid var(--gold-dim); border-radius:999px; padding:5px 16px; font-size:11px; font-weight:700; color:var(--gold); letter-spacing:.12em; margin-bottom:16px; }
.hero-title { font-size:clamp(34px,5.5vw,58px); font-weight:900; line-height:1.15; margin-bottom:20px; }
.hero-title .accent { background:linear-gradient(135deg,#e8d5a0,#c9a04a,#9b6fd4); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; }
.hero-sub   { font-size:15px; color:var(--text-dim); margin-bottom:32px; line-height:1.8; }
.hero-btns  { display:flex; gap:12px; flex-wrap:wrap; }
.hero-visual { position:relative; height:420px; display:flex; align-items:center; justify-content:center; }
.hero-moon   { position:absolute; width:280px; height:280px; border-radius:50%; background:radial-gradient(circle at 38% 38%,rgba(201,160,74,.08),transparent 65%),radial-gradient(circle,rgba(123,82,171,.15) 0%,transparent 70%); border:1px solid rgba(201,160,74,.12); animation:moonPulse 6s ease-in-out infinite; }
@keyframes moonPulse { 0%,100%{box-shadow:0 0 40px rgba(201,160,74,.08),0 0 80px rgba(123,82,171,.06)} 50%{box-shadow:0 0 60px rgba(201,160,74,.14),0 0 120px rgba(123,82,171,.1)} }
.hero-cards  { position:relative; z-index:1; display:flex; align-items:flex-end; }
.hero-card-placeholder { width:100px; height:160px; border-radius:8px; background:linear-gradient(135deg,#2d1f4a,#1a1040); border:1px solid rgba(201,160,74,.3); display:flex; align-items:center; justify-content:center; font-size:32px; box-shadow:0 8px 30px rgba(0,0,0,.6); flex-shrink:0; }
.hero-card-placeholder:nth-child(1){transform:rotate(-15deg) translateY(10px);}
.hero-card-placeholder:nth-child(2){transform:rotate(-5deg) translateY(-5px);width:115px;height:180px;z-index:2;position:relative;}
.hero-card-placeholder:nth-child(3){transform:rotate(8deg) translateY(15px);}
.hero-card-placeholder:nth-child(4){transform:rotate(20deg) translateY(25px);}
.hero-card-img { width:100px; border-radius:8px; box-shadow:0 8px 30px rgba(0,0,0,.6); border:1px solid rgba(201,160,74,.3); }
.hero-card-img:nth-child(1){transform:rotate(-15deg) translateY(10px);}
.hero-card-img:nth-child(2){transform:rotate(-5deg) translateY(-5px);width:115px;z-index:2;position:relative;}
.hero-card-img:nth-child(3){transform:rotate(8deg) translateY(15px);}
.hero-card-img:nth-child(4){transform:rotate(20deg) translateY(25px);}

/* ヒーロー背景画像版 */
.hero-bg {
  background-size: cover;
  background-position: center top;
  background-repeat: no-repeat;
  min-height: 100vh;
  display: flex;
  align-items: flex-end;
  justify-content: flex-start;
  padding: 0 0 100px;
  position: relative;
}
.hero-overlay {
  position: absolute; inset: 0;
  background:
    linear-gradient(to right,  rgba(11,9,22,.72) 0%, rgba(11,9,22,.45) 45%, rgba(11,9,22,.05) 100%),
    linear-gradient(to bottom, rgba(11,9,22,.15) 0%, rgba(11,9,22,0)   35%, rgba(11,9,22,.5)  70%, rgba(11,9,22,.82) 100%);
}
.hero-bg-inner {
  position: relative; z-index: 1;
  max-width: 560px;
  padding-bottom: 20px;
}
/* ヒーローテキスト */
.hero-bg-text { display: block; }
.hero-bg-label {
  display: inline-block;
  font-size: 12px;
  font-weight: 700;
  color: var(--gold);
  letter-spacing: .12em;
  margin-bottom: 12px;
  text-shadow: 0 2px 8px rgba(0,0,0,.9);
  background: rgba(0,0,0,.25);
  padding: 4px 14px;
  border-radius: 999px;
  border: 1px solid rgba(201,160,74,.3);
}
.hero-bg-title {
  font-size: clamp(32px, 5.5vw, 54px);
  font-weight: 900;
  line-height: 1.2;
  margin-bottom: 14px;
  text-shadow: 0 2px 20px rgba(0,0,0,.9), 0 4px 40px rgba(0,0,0,.6);
}
.hero-bg-sub {
  font-size: 16px;
  color: var(--text-dim);
  margin-bottom: 28px;
  text-shadow: 0 2px 10px rgba(0,0,0,.9);
  letter-spacing: .08em;
}
.hero-btns .btn-gold {
  background: linear-gradient(135deg, rgba(201,160,74,.85), rgba(232,201,106,.9));
  border: 1.5px solid rgba(232,213,160,.6);
  backdrop-filter: blur(4px);
}
.hero-btns .btn-outline {
  backdrop-filter: blur(4px);
  background: rgba(255,255,255,.08);
}
@media (max-width: 680px) {
  .hero-bg { min-height: 85vh; padding: 0 0 60px; align-items: flex-end; }
  .hero-bg-title { font-size: clamp(32px, 8vw, 48px); }
}

/* すぐに占う */
.quick-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:20px; }
.quick-card { text-align:center; padding:30px 20px; }
.quick-icon  { width:110px; height:110px; margin:16px auto; display:flex; align-items:center; justify-content:center; font-size:48px; background:none; border:none; border-radius:0; overflow:visible; }
.quick-icon img { width:110px; height:110px; object-fit:contain; display:block; }
.quick-title { font-size:18px; font-weight:800; margin-bottom:6px; }
.quick-sub   { font-size:13px; color:var(--text-dim); margin-bottom:20px; }

/* 毎日更新 */
.daily-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:16px; }
.daily-item { text-align:center; padding:24px 16px; background:linear-gradient(145deg,rgba(34,25,66,.8),rgba(20,15,45,.9)); border:1px solid rgba(201,160,74,.18); border-radius:var(--radius); transition:transform .25s,border-color .25s; text-decoration:none; color:inherit; display:block; }
.daily-item:hover { transform:translateY(-4px); border-color:rgba(201,160,74,.4); color:inherit; }
.daily-icon  { font-size:36px; margin-bottom:12px; display:flex; align-items:center; justify-content:center; height:72px; }
.daily-title { font-size:14px; font-weight:800; margin-bottom:6px; }
.daily-badge { display:inline-block; padding:3px 10px; border-radius:999px; font-size:11px; font-weight:700; background:rgba(201,160,74,.15); color:var(--gold); border:1px solid var(--gold-dim); }

/* ランキング */
.rank-section { background:linear-gradient(180deg,transparent,rgba(28,22,55,.6),transparent); }
.rank-grid    { display:grid; grid-template-columns:repeat(12,1fr); gap:10px; align-items:end; }
.rank-item    { text-align:center; }
.rank-num     { font-size:11px; font-weight:800; color:var(--gold); margin-bottom:6px; }
.zodiac-circle { width:44px; height:44px; border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:20px; margin:0 auto 6px; background:linear-gradient(135deg,rgba(123,82,171,.3),rgba(60,30,100,.5)); border:1px solid rgba(201,160,74,.25); }
.rank-item:nth-child(1) .zodiac-circle{background:linear-gradient(135deg,#c9a04a,#8a6010);border-color:#c9a04a;width:52px;height:52px;font-size:24px;}
.rank-item:nth-child(2) .zodiac-circle{background:linear-gradient(135deg,#a8a8a8,#606060);border-color:#a8a8a8;width:48px;height:48px;}
.rank-item:nth-child(3) .zodiac-circle{background:linear-gradient(135deg,#cd7f32,#8b4513);border-color:#cd7f32;width:46px;height:46px;}
.zodiac-name { font-size:10px; color:var(--text-dim); }

/* 占いを学ぶ */
.learn-grid  { display:grid; grid-template-columns:repeat(3,1fr); gap:20px; }
.learn-card  { padding:0; overflow:hidden; }
.learn-thumb { height:160px; display:flex; align-items:center; justify-content:center; font-size:64px; }
.learn-body  { padding:20px; }
.learn-title { font-size:18px; font-weight:800; margin-bottom:12px; }
.learn-list  { list-style:none; padding:0; margin-bottom:20px; }
.learn-list li { font-size:13px; color:var(--text-dim); padding:3px 0; }
.learn-list li::before { content:'・'; color:var(--gold); }

/* 保存機能 */
.save-bg   { background:linear-gradient(135deg,rgba(34,25,66,.5),rgba(20,15,45,.7)); }
.save-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:20px; margin-bottom:40px; }
.save-item { text-align:center; padding:30px 20px; }
.save-icon { font-size:40px; margin-bottom:16px; }
.save-title{ font-size:15px; font-weight:800; margin-bottom:6px; }
.save-sub  { font-size:13px; color:var(--text-dim); }
.save-note { margin-top:12px; font-size:12px; color:var(--text-dim); text-align:center; }

/* AI巫女 */
.ai-bg    { background:linear-gradient(135deg,#1a0f2e,#2a1040,#1a0f2e); border-top:1px solid rgba(201,160,74,.1); border-bottom:1px solid rgba(201,160,74,.1); }
.ai-inner { display:grid; grid-template-columns:1fr 1fr; gap:40px; align-items:center; }
.ai-orb   { width:220px; height:220px; border-radius:50%; background:radial-gradient(circle at 40% 35%,rgba(155,111,212,.4) 0%,rgba(60,20,120,.6) 50%,rgba(20,10,50,.9) 100%); border:2px solid rgba(155,111,212,.35); display:flex; align-items:center; justify-content:center; font-size:80px; animation:orbPulse 5s ease-in-out infinite; margin:0 auto; overflow:hidden; }
@keyframes orbPulse{0%,100%{box-shadow:0 0 60px rgba(123,82,171,.3)}50%{box-shadow:0 0 90px rgba(123,82,171,.5)}}
.ai-text h2 { font-size:clamp(22px,3vw,30px); font-weight:900; margin-bottom:12px; }
.ai-text p  { color:var(--text-dim); margin-bottom:24px; }
.ai-tags    { display:flex; flex-wrap:wrap; gap:8px; margin-bottom:28px; }
.ai-tag     { padding:5px 14px; border-radius:999px; font-size:12px; font-weight:700; background:rgba(123,82,171,.2); border:1px solid rgba(155,111,212,.3); color:var(--purple-lt); }

/* 人気コンテンツ */
.popular-grid  { display:grid; grid-template-columns:repeat(3,1fr); gap:20px; }
.popular-card  { padding:0; overflow:hidden; }
.popular-thumb { height:220px; display:flex; align-items:center; justify-content:center; font-size:64px; background:linear-gradient(135deg,#2d1f4a,#1a1040); overflow:hidden; transition:transform .3s; }
.popular-card:hover .popular-thumb { transform:scale(1.05); }
.popular-body  { padding:16px; }
.popular-title { font-size:15px; font-weight:800; margin-bottom:6px; }
.popular-sub   { font-size:12px; color:var(--text-dim); }

/* みんなの声 */
.voices-list { display:flex; flex-direction:column; gap:16px; max-width:700px; margin:0 auto; }
.voice-item  { display:flex; gap:16px; align-items:flex-start; background:linear-gradient(145deg,rgba(34,25,66,.7),rgba(20,15,45,.8)); border:1px solid rgba(201,160,74,.15); border-radius:var(--radius); padding:20px; }
.voice-avatar{ width:44px; height:44px; border-radius:50%; flex-shrink:0; background:linear-gradient(135deg,#7b52ab,#9b6fd4); display:flex; align-items:center; justify-content:center; font-size:20px; }
.voice-text  { font-size:14px; margin-bottom:6px; }
.voice-meta  { font-size:12px; color:var(--text-dim); text-align:right; }

/* ご利用の流れ */
.flow-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:0; position:relative; }
.flow-grid::before { content:''; position:absolute; top:40px; left:10%; right:10%; height:1px; background:linear-gradient(90deg,transparent,var(--gold-dim),var(--gold-dim),transparent); }
.flow-item { text-align:center; padding:16px 12px; position:relative; }
.flow-icon-wrap { width:72px; height:72px; border-radius:50%; background:linear-gradient(135deg,rgba(34,25,66,.9),rgba(20,15,45,.95)); border:2px solid var(--gold-dim); display:flex; align-items:center; justify-content:center; font-size:30px; margin:0 auto 16px; position:relative; z-index:1; transition:border-color .25s,transform .25s; }
.flow-item:hover .flow-icon-wrap { border-color:var(--gold); transform:scale(1.08); }
.flow-step  { font-size:11px; color:var(--gold); font-weight:700; margin-bottom:6px; }
.flow-title { font-size:15px; font-weight:800; margin-bottom:6px; }
.flow-sub   { font-size:12px; color:var(--text-dim); }
.flow-arrow { position:absolute; top:36px; right:-6px; z-index:2; font-size:16px; color:var(--gold); }

/* もっと深く */
.deep-grid  { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
.deep-card  { text-align:center; padding:36px 28px; }
.deep-title { font-size:17px; font-weight:800; margin-bottom:12px; }
.deep-sub   { font-size:13px; color:var(--text-dim); margin-bottom:24px; line-height:1.8; }
.btn-line   { display:inline-block; padding:10px 24px; border-radius:999px; font-size:14px; font-weight:700; background:#06c755; color:#fff; border:2px solid #06c755; text-decoration:none; transition:opacity .2s; }
.btn-line:hover { opacity:.85; color:#fff; }

/* CTAバナー */
.cta-banner {
  padding: 100px 0;
  background:
    radial-gradient(ellipse at 50% 0%,   rgba(123,82,171,.35) 0%, transparent 60%),
    radial-gradient(ellipse at 50% 100%, rgba(60,20,100,.4)   0%, transparent 55%),
    linear-gradient(180deg, #0d0820 0%, #160b30 50%, #0d0820 100%);
  background-size: cover;
  background-position: center;
  text-align: center;
  position: relative;
  overflow: hidden;
}
.cta-overlay {
  position: absolute; inset: 0;
  background: rgba(8,5,18,.3);
}
/* 星の装飾 */
.cta-stars { position:absolute; inset:0; pointer-events:none; }
.cta-star  { position:absolute; color:var(--gold); opacity:.55; }
.cta-star.s1 { font-size:22px; top:18%; left:8%;  opacity:.6; }
.cta-star.s2 { font-size:13px; top:12%; left:25%; opacity:.4; }
.cta-star.s3 { font-size:18px; top:22%; right:12%; opacity:.55; }
.cta-star.s4 { font-size:11px; top:65%; left:15%; opacity:.4; }
.cta-star.s5 { font-size:20px; top:70%; right:8%;  opacity:.5; }
.cta-star.s6 { font-size:14px; top:55%; right:28%; opacity:.35; }

.cta-accent  { font-size:13px; color:#e8c86a; letter-spacing:.18em; margin-bottom:14px; opacity:.85; }
.cta-heading {
  font-size: clamp(28px,4.5vw,52px);
  font-weight: 900;
  margin-bottom: 16px;
  color: #ffffff;
  text-shadow: 0 2px 20px rgba(0,0,0,.6);
  letter-spacing: .04em;
}
.cta-sub {
  font-size: 16px;
  color: #d8cef0;
  margin-bottom: 36px;
  text-shadow: 0 1px 8px rgba(0,0,0,.5);
  line-height: 1.8;
}
/* CTAボタン（白背景×濃い文字 → コントラスト比 約14:1） */
.btn-cta {
  display: inline-block;
  padding: 16px 44px;
  border-radius: 999px;
  font-size: 17px;
  font-weight: 900;
  background: #ffffff;
  color: #1a0f2e;
  border: 3px solid #ffffff;
  text-decoration: none;
  letter-spacing: .06em;
  transition: background .25s, color .25s, transform .2s;
  box-shadow: 0 4px 24px rgba(255,255,255,.2);
}
.btn-cta:hover {
  background: #e8c86a;
  border-color: #e8c86a;
  color: #1a0f2e;
  transform: translateY(-3px);
}

/* =============================================
   記事一覧（index / archive / category）
============================================= */
.posts-header { padding:50px 0 30px; text-align:center; }
.posts-header h1 { font-size:clamp(22px,3vw,32px); font-weight:900; }
.posts-header p  { color:var(--text-dim); margin-top:8px; }
.posts-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; padding:0 0 60px; }
.post-card  { padding:0; overflow:hidden; display:flex; flex-direction:column; }
.post-thumbnail { width:100%; height:180px; object-fit:cover; filter:brightness(.75) saturate(.9); transition:filter .3s,transform .3s; }
.post-thumb-wrap { overflow:hidden; }
.post-card:hover .post-thumbnail { filter:brightness(.9) saturate(1.1); transform:scale(1.03); }
.post-thumb-placeholder { height:180px; background:linear-gradient(135deg,#2d1f4a,#1a1040); display:flex; align-items:center; justify-content:center; font-size:48px; }
.post-body  { padding:20px; flex:1; display:flex; flex-direction:column; }
.post-cat   { display:inline-block; padding:3px 10px; border-radius:999px; font-size:11px; font-weight:700; background:rgba(201,160,74,.15); color:var(--gold); border:1px solid var(--gold-dim); margin-bottom:10px; }
.post-title { font-size:16px; font-weight:800; margin-bottom:8px; line-height:1.4; }
.post-title a { color:var(--text); }
.post-title a:hover { color:var(--gold-lt); }
.post-excerpt { font-size:13px; color:var(--text-dim); line-height:1.6; flex:1; }
.post-meta    { display:flex; align-items:center; gap:12px; margin-top:14px; padding-top:14px; border-top:1px solid rgba(201,160,74,.1); }
.post-date    { font-size:12px; color:var(--text-dim); }
.post-date::before { content:'📅'; margin-right:4px; font-size:10px; }
.pagination-wrap { text-align:center; padding:0 0 60px; }
.pagination-wrap .nav-links { display:flex; justify-content:center; align-items:center; gap:8px; flex-wrap:wrap; }
.pagination-wrap .page-numbers { display:inline-flex; align-items:center; justify-content:center; width:40px; height:40px; border-radius:50%; background:rgba(34,25,66,.8); border:1px solid rgba(201,160,74,.2); color:var(--text-dim); font-size:14px; transition:all .2s; }
.pagination-wrap .page-numbers.current { background:linear-gradient(135deg,#c9a04a,#e8c96a); color:#2a1a00; border-color:#c9a04a; font-weight:700; }
.pagination-wrap .page-numbers:hover:not(.current) { border-color:var(--gold); color:var(--gold-lt); }

/* =============================================
   記事本文（single）
============================================= */
.single-header { padding:60px 0 30px; }
.single-cats   { display:flex; gap:8px; flex-wrap:wrap; margin-bottom:16px; }
.single-cat    { padding:4px 12px; border-radius:999px; font-size:12px; font-weight:700; background:rgba(201,160,74,.15); color:var(--gold); border:1px solid var(--gold-dim); text-decoration:none; }
.single-title  { font-size:clamp(22px,4vw,36px); font-weight:900; line-height:1.3; margin-bottom:16px; }
.single-meta   { display:flex; align-items:center; gap:16px; color:var(--text-dim); font-size:13px; margin-bottom:30px; }
.single-thumbnail { width:100%; max-height:420px; object-fit:cover; border-radius:var(--radius); margin-bottom:40px; filter:brightness(.8) saturate(.9); border:1px solid rgba(201,160,74,.15); }
.single-body   { background:linear-gradient(145deg,rgba(28,20,55,.8),rgba(20,15,45,.9)); border:1px solid rgba(201,160,74,.12); border-radius:var(--radius-lg); padding:40px; margin-bottom:40px; }
/* 記事本文のスタイル */
.single-body h2 { font-size:22px; font-weight:800; margin:40px 0 16px; padding:12px 16px; background:linear-gradient(135deg,rgba(123,82,171,.2),rgba(60,30,100,.15)); border-left:3px solid var(--gold); border-radius:0 8px 8px 0; }
.single-body h3 { font-size:18px; font-weight:700; margin:32px 0 12px; color:var(--gold-lt); }
.single-body h4 { font-size:16px; font-weight:700; margin:24px 0 10px; }
/* インラインスタイルの暗色カラーをテーマカラーで上書き */
.single-body p  { margin-bottom:18px; line-height:1.85; color:var(--text) !important; }
.single-body ul,.single-body ol { margin:16px 0 20px; }
.single-body li { margin-bottom:8px; line-height:1.7; }
.single-body a  { color:var(--gold-lt); text-decoration:underline; }
.single-body strong { color:var(--gold-lt); font-weight:700; }
.single-body em     { color:var(--purple-lt); }
.single-body blockquote { margin:24px 0; padding:16px 20px; background:rgba(123,82,171,.1); border-left:3px solid var(--purple); border-radius:0 8px 8px 0; color:var(--text-dim); font-style:italic; }
.single-body img    { border-radius:8px; margin:20px auto; box-shadow:0 4px 20px rgba(0,0,0,.4); }
.single-body table  { width:100%; border-collapse:collapse; margin:20px 0; }
.single-body th { background:rgba(123,82,171,.25); padding:10px 14px; text-align:left; border:1px solid rgba(201,160,74,.15); font-size:13px; }
.single-body td { padding:10px 14px; border:1px solid rgba(201,160,74,.1); font-size:14px; color:var(--text) !important; }
.single-body tr:hover td { background:rgba(34,25,66,.5); }
.single-body code { background:rgba(123,82,171,.2); padding:2px 6px; border-radius:4px; font-size:.9em; color:var(--purple-lt); }
.single-body pre  { background:rgba(10,8,20,.8); border:1px solid rgba(201,160,74,.15); border-radius:8px; padding:20px; overflow-x:auto; margin:20px 0; }
.single-body pre code { background:none; padding:0; }
/* 著者情報 */
.author-box    { display:flex; gap:24px; align-items:flex-start; background:linear-gradient(145deg,rgba(34,25,66,.75),rgba(20,15,45,.9)); border:1px solid rgba(201,160,74,.25); border-radius:var(--radius); padding:28px; margin-bottom:40px; }
.author-avatar { width:72px; height:72px; border-radius:50%; background:linear-gradient(135deg,#7b52ab,#c9a04a); display:flex; align-items:center; justify-content:center; font-size:32px; flex-shrink:0; box-shadow:0 0 18px rgba(155,114,203,.4); }
.author-avatar img { width:100%; height:100%; object-fit:cover; border-radius:50%; }
.author-info   { flex:1; min-width:0; }
.author-label  { font-size:11px; font-weight:700; letter-spacing:.1em; color:var(--gold); text-transform:uppercase; margin-bottom:6px; opacity:.8; }
.author-name   { font-size:16px; font-weight:900; color:var(--text); margin-bottom:2px; }
.author-site   { font-size:11px; color:var(--gold-lt); letter-spacing:.08em; margin-bottom:10px; opacity:.7; }
.author-bio    { font-size:13px; color:var(--text-dim); line-height:1.8; margin-bottom:14px; }
.author-links  { display:flex; flex-wrap:wrap; gap:8px; }
.author-link   { font-size:12px; color:var(--text-dim); text-decoration:none; padding:4px 12px; border:1px solid rgba(201,160,74,.25); border-radius:999px; transition:all .2s; }
.author-link:hover { color:var(--gold-lt); border-color:var(--gold); background:rgba(201,160,74,.08); }
/* 前後の記事 */
.post-nav { display:grid; grid-template-columns:1fr 1fr; gap:16px; margin-bottom:60px; }
.post-nav-link { padding:20px; background:linear-gradient(145deg,rgba(34,25,66,.8),rgba(20,15,45,.9)); border:1px solid rgba(201,160,74,.15); border-radius:var(--radius); transition:border-color .25s,transform .25s; }
.post-nav-link:hover { border-color:rgba(201,160,74,.4); transform:translateY(-2px); }
.post-nav-label { font-size:11px; color:var(--gold); font-weight:700; margin-bottom:6px; display:block; }
.post-nav-title { font-size:14px; color:var(--text); line-height:1.4; }
/* 関連記事 */
.related-posts { margin-bottom:60px; }
.related-title { font-size:18px; font-weight:800; margin-bottom:20px; display:flex; align-items:center; gap:8px; }
.related-title::before { content:'✦'; color:var(--gold); font-size:14px; }
.related-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:16px; }

/* =============================================
   固定ページ（page）
============================================= */
.page-header { padding:50px 0 20px; }
.page-title  { font-size:clamp(24px,4vw,36px); font-weight:900; margin-bottom:16px; }
.page-body   { background:linear-gradient(145deg,rgba(28,20,55,.8),rgba(20,15,45,.9)); border:1px solid rgba(201,160,74,.12); border-radius:var(--radius-lg); padding:40px; margin-bottom:60px; }
/* page-bodyもsingle-bodyと同じスタイル継承 */
.page-body h2,.page-body h3,.page-body h4,
.page-body p,.page-body ul,.page-body ol,.page-body li,
.page-body a,.page-body strong,.page-body em,
.page-body blockquote,.page-body img,.page-body table,
.page-body th,.page-body td,.page-body tr { }
.page-body h2 { font-size:22px; font-weight:800; margin:40px 0 16px; padding:12px 16px; background:linear-gradient(135deg,rgba(123,82,171,.2),rgba(60,30,100,.15)); border-left:3px solid var(--gold); border-radius:0 8px 8px 0; }
.page-body h3 { font-size:18px; font-weight:700; margin:32px 0 12px; color:var(--gold-lt); }
.page-body p  { margin-bottom:18px; line-height:1.85; }
.page-body ul,.page-body ol { margin:16px 0 20px; }
.page-body li { margin-bottom:8px; line-height:1.7; }
.page-body a  { color:var(--gold-lt); text-decoration:underline; }

/* =============================================
   404ページ
============================================= */
.not-found { text-align:center; padding:100px 20px; }
.not-found-num  { font-size:120px; font-weight:900; line-height:1; background:linear-gradient(135deg,#e8d5a0,#c9a04a,#9b6fd4); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; }
.not-found h2   { font-size:24px; font-weight:800; margin:16px 0 12px; }
.not-found p    { color:var(--text-dim); margin-bottom:32px; }
.not-found-icon { font-size:80px; margin-bottom:24px; }

/* =============================================
   検索フォーム
============================================= */
.search-form-wrap { max-width:600px; margin:0 auto 60px; }
.search-form      { display:flex; gap:0; }
.search-input { flex:1; padding:14px 20px; background:rgba(34,25,66,.8); border:1px solid rgba(201,160,74,.3); border-right:none; border-radius:var(--radius) 0 0 var(--radius); color:var(--text); font-size:15px; outline:none; }
.search-input:focus { border-color:var(--gold); }
.search-input::placeholder { color:var(--text-dim); }
.search-submit { padding:14px 24px; background:linear-gradient(135deg,#c9a04a,#e8c96a); border:none; border-radius:0 var(--radius) var(--radius) 0; cursor:pointer; font-size:16px; color:#2a1a00; font-weight:700; transition:opacity .2s; }
.search-submit:hover { opacity:.85; }

/* =============================================
   パンくずリスト
============================================= */
.breadcrumb {
  display:flex; align-items:center; flex-wrap:wrap; gap:4px;
  font-size:12px; color:var(--text-dim);
  margin-bottom:20px; padding:8px 0;
}
.breadcrumb a { color:var(--text-dim); text-decoration:none; transition:color .2s; }
.breadcrumb a:hover { color:var(--gold-lt); }
.bc-sep  { color:rgba(255,255,255,.2); margin:0 2px; }
.bc-current { color:var(--text); }

/* =============================================
   スクロールアニメ
============================================= */
.fade-in { opacity:0; transform:translateY(24px); transition:opacity .6s ease,transform .6s ease; }
.fade-in.visible { opacity:1; transform:none; }

/* =============================================
   レスポンシブ
============================================= */
@media (max-width:900px) {
  .hero-inner   { grid-template-columns:1fr; text-align:center; }
  .hero-btns    { justify-content:center; }
  .hero-visual  { height:260px; }
  .rank-grid    { grid-template-columns:repeat(6,1fr); }
  .daily-grid   { grid-template-columns:repeat(2,1fr); }
  .ai-inner     { grid-template-columns:1fr; text-align:center; }
  .ai-tags      { justify-content:center; }
  .footer-inner { grid-template-columns:1fr 1fr; }
  .posts-grid   { grid-template-columns:repeat(2,1fr); }
  .related-grid { grid-template-columns:repeat(2,1fr); }
}
@media (max-width:680px) {
  .nav-links    { display:none; }
  .hamburger    { display:flex; }
  .quick-grid   { grid-template-columns:1fr; }
  .learn-grid   { grid-template-columns:1fr; }
  .popular-grid { grid-template-columns:1fr; }
  .deep-grid    { grid-template-columns:1fr; }
  .flow-grid    { grid-template-columns:repeat(2,1fr); }
  .flow-grid::before { display:none; }
  .rank-grid    { grid-template-columns:repeat(4,1fr); gap:6px; }
  .daily-grid   { grid-template-columns:repeat(2,1fr); }
  .save-grid    { grid-template-columns:1fr; }
  .footer-inner { grid-template-columns:1fr; }
  .posts-grid   { grid-template-columns:1fr; }
  .post-nav     { grid-template-columns:1fr; }
  .related-grid { grid-template-columns:1fr; }
  .single-body,.page-body { padding:24px; }
  .author-box   { flex-direction:column; align-items:center; text-align:center; }
  .author-links { justify-content:center; }
  /* ヒーローボタン縦並び */
  .hero-btns    { flex-direction:column; align-items:flex-start; gap:10px; }
  .hero-btns .btn-lg { font-size:14px; padding:13px 26px; width:100%; justify-content:center; max-width:280px; }
  /* AI巫女イラスト（スマホ：縦並び） */
  .page-section.ai-bg .ai-inner { grid-template-columns:1fr; min-height:auto; }
  .page-section.ai-bg .ai-text  { padding:28px 20px; }
  .ai-miko-wrap { min-height:220px; }
  .ai-miko-img  { min-height:220px; object-position:10% center; }
  /* みんなの声 */
  .voices-list  { padding:0 4px; }
  /* CTAテキスト */
  .cta-heading  { font-size:clamp(22px,6vw,36px); }
}

/* 極小画面（375px以下） */
@media (max-width:400px) {
  .rank-grid    { grid-template-columns:repeat(3,1fr); }
  .zodiac-circle { width:38px; height:38px; font-size:16px; }
  .rank-item:nth-child(1) .zodiac-circle { width:44px; height:44px; font-size:20px; }
  .rank-item:nth-child(2) .zodiac-circle { width:40px; height:40px; }
  .rank-item:nth-child(3) .zodiac-circle { width:38px; height:38px; }
  .zodiac-name  { font-size:9px; }
  .rank-num     { font-size:10px; }
  .flow-grid    { grid-template-columns:1fr; }
}

/* =============================================
   ライトセクション（フロントページ本文）
   ※ コントラスト比 WCAG 2.1 AA 準拠
============================================= */
.page-section {
  --text:     #1a0f2e;
  --text-dim: #3d2d60;  /* 旧:#6b5a8a → #3d2d60（コントラスト比 9.8:1）*/
  background: #f7f3ff;
}
.page-section h1,
.page-section h2,
.page-section h3,
.page-section h4 { color: #1a0f2e; }
.page-section p   { color: #2d1f50; }

/* セクションタイトルをライト向けに */
.page-section .section-title { color: #2d1547; }
.page-section .section-title::before { background: linear-gradient(90deg,transparent,rgba(123,82,171,.4)); }
.page-section .section-title::after  { background: linear-gradient(90deg,rgba(123,82,171,.4),transparent); }

/* セクションヘッダー行（タイトル＋もっとみるリンク） */
.section-header-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 40px;
}
.section-header-row .section-title { margin-bottom: 0; }
.section-more-link {
  font-size: 13px;
  font-weight: 600;
  color: #4d3099;  /* 旧:#7b52ab → #4d3099（コントラスト比 7.2:1）*/
  white-space: nowrap;
  flex-shrink: 0;
  transition: color .2s;
}
.section-more-link:hover { color: #3d2080; }  /* 旧:#9b6fd4（低コントラスト）→ 濃いめの紫 */

/* カード */
.page-section .card {
  background: #ffffff;
  border-color: rgba(123,82,171,.14);
  box-shadow: 0 2px 14px rgba(123,82,171,.07);
}
.page-section .card:hover {
  border-color: rgba(123,82,171,.32);
  box-shadow: 0 8px 28px rgba(123,82,171,.14);
  transform: translateY(-4px);
}

/* ボタン：ライトセクション上での btn-outline はゴールドでなく濃い紫に */
.page-section .btn-outline {
  border-color: rgba(61,32,128,.5) !important;
  color: #3d2080 !important;
}
.page-section .btn-outline:hover {
  background: rgba(61,32,128,.07) !important;
  color: #2d1060 !important;
}

/* すぐに占う */
.page-section .quick-icon {
  background: none;
  border: none;
  border-radius: 0;
  width: 110px;
  height: 110px;
}
.page-section .quick-title { color: #1a0f2e; }
.page-section .quick-sub   { color: #3d2d60; }  /* 旧:#6b5a8a */

/* 毎日更新タイル（淡いラベンダー） */
.page-section .daily-item {
  background: rgba(123,82,171,.07);
  border-color: rgba(123,82,171,.12);
}
.page-section .daily-item:hover {
  background: rgba(123,82,171,.13);
  border-color: rgba(123,82,171,.3);
}
.page-section .daily-title { color: #2d1547; }
.page-section .daily-badge {
  background: rgba(123,82,171,.1);
  color: #4d3099;  /* 旧:#7b52ab → 濃いめ */
  border-color: rgba(123,82,171,.2);
}

/* ランキング */
.page-section.rank-section { background: #f0eaff; }
.page-section .rank-section { background: #f0eaff; }
.page-section .zodiac-name  { color: #3d2d60; }  /* 旧:#6b5a8a */
.page-section .rank-num     { color: #7a4500; }  /* 旧:#c9a04a（ラベンダー背景で2.3:1 失敗）→ ダークアンバー（6.6:1）*/
.page-section .zodiac-circle {
  background: linear-gradient(135deg,rgba(123,82,171,.25),rgba(90,50,150,.4));
  border-color: rgba(123,82,171,.3);
}
.page-section .rank-item:nth-child(1) .zodiac-circle { background:linear-gradient(135deg,#c9a04a,#8a6010); border-color:#c9a04a; }
.page-section .rank-item:nth-child(2) .zodiac-circle { background:linear-gradient(135deg,#a8a8a8,#606060); border-color:#a8a8a8; }
.page-section .rank-item:nth-child(3) .zodiac-circle { background:linear-gradient(135deg,#cd7f32,#8b4513); border-color:#cd7f32; }

/* 占いを学ぶ */
.page-section .learn-title { color: #1a0f2e; }
.page-section .learn-list li { color: #3d2d60; }  /* 旧:#6b5a8a */

/* AI巫女バナー */
.ai-banner {
  position: relative;
  min-height: 280px;
  background: linear-gradient(135deg,#130b28,#1e1040,#130b28);
  border-top:    1px solid rgba(201,160,74,.1);
  border-bottom: 1px solid rgba(201,160,74,.1);
  overflow: hidden;
  display: flex;
  align-items: center;
}
.ai-banner-img {
  position: absolute;
  left: 0; top: 0; bottom: 0;
  width: 42%;
  overflow: hidden;
}
.ai-banner-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: left center;
  display: block;
}
.ai-banner-text {
  margin-left: 44%;
  padding: 36px 48px 36px 16px;
  flex: 1;
  display: flex;
  flex-direction: column;
  justify-content: center;
  position: relative;
  z-index: 1;
}
.ai-banner-text h2 { font-size:clamp(18px,2.2vw,26px); font-weight:900; color:#f0e6d3; margin-bottom:10px; line-height:1.35; }
.ai-banner-text p  { font-size:14px; color:#b8a9d0; margin-bottom:16px; line-height:1.8; }
.ai-banner .ai-tag {
  background: rgba(123,82,171,.2);
  border: 1px solid rgba(155,111,212,.3);
  color: #9b6fd4;
  padding: 4px 12px;
  border-radius: 999px;
  font-size: 12px;
  font-weight: 700;
}
@media (max-width:900px) {
  .ai-banner       { flex-direction:column; align-items:flex-start; min-height:auto; }
  .ai-banner-img   { position:relative; width:100%; height:220px; }
  .ai-banner-text  { margin-left:0; padding:28px 20px; width:100%; }
  .ai-banner .ai-tags { justify-content:center; }
}

/* AI巫女はダーク維持（バナースタイル） */
.page-section.ai-bg {
  --text:     #f0e6d3;
  --text-dim: #b8a9d0;
  background: linear-gradient(135deg,#130b28,#1e1040,#130b28);
  border-top:    1px solid rgba(201,160,74,.1);
  border-bottom: 1px solid rgba(201,160,74,.1);
  padding: 0 !important;
  overflow: hidden;
}
.page-section.ai-bg .container { padding: 0; max-width: 100%; }
.page-section.ai-bg h2,
.page-section.ai-bg h3 { color: #f0e6d3; }
.page-section.ai-bg p  { color: #b8a9d0; }
.page-section.ai-bg .ai-tag {
  background: rgba(123,82,171,.2);
  border-color: rgba(155,111,212,.3);
  color: #9b6fd4;
}
/* グリッドをバナー用に調整 */
.page-section.ai-bg .ai-inner {
  grid-template-columns: 2fr 3fr;
  gap: 0;
  align-items: stretch;
  min-height: 280px;
}
.page-section.ai-bg .ai-text {
  padding: 36px 48px 36px 36px;
  display: flex;
  flex-direction: column;
  justify-content: center;
}
.page-section.ai-bg .ai-text h2 { font-size: clamp(20px,2.5vw,28px); margin-bottom:10px; }
.page-section.ai-bg .ai-text p  { margin-bottom:18px; font-size:14px; }

/* AI巫女イラスト */
.ai-miko-wrap {
  overflow: hidden;
  min-height: 280px;
  display: flex;
  align-items: stretch;
}
.ai-miko-img  {
  width: 100%;
  height: 100%;
  min-height: 280px;
  object-fit: cover;
  object-position: 5% center;
  display: block;
}

/* 人気コンテンツ */
.page-section .popular-thumb {
  background: linear-gradient(135deg,#e0d4f7,#cfc2ef);
  height: 220px;
}
.page-section .popular-title { color: #1a0f2e; }
.page-section .popular-sub   { color: #6b5a8a; }

/* みんなの声 */
.page-section .voice-item {
  background: #ffffff;
  border-color: rgba(123,82,171,.12);
}
.page-section .voice-text { color: #2d1547; }
.page-section .voice-meta { color: #6b5a8a; }
/* アバター：グレー人物アイコン */
.page-section .voice-avatar {
  background: #d8d0e8;
  color: #9080b4;
  font-size: 22px;
}

/* ご利用の流れ */
.page-section .flow-icon-wrap {
  background: #ffffff;
  border-color: rgba(123,82,171,.28);
}
.page-section .flow-grid::before {
  background: linear-gradient(90deg,transparent,rgba(123,82,171,.22),rgba(123,82,171,.22),transparent);
}
.page-section .flow-step  { color: #c9a04a; }
.page-section .flow-title { color: #1a0f2e; }
.page-section .flow-sub   { color: #6b5a8a; }
.page-section .flow-arrow { color: rgba(123,82,171,.45); }

/* もっと深く（全カード同一スタイル） */
.page-section .deep-card {
  background: #ffffff !important;
  border-color: rgba(123,82,171,.14) !important;
}
.page-section .deep-title { color: #1a0f2e; }
.page-section .deep-sub   { color: #6b5a8a; }

/* ===== 運営者情報テーブル ===== */
.about-table { width:100%; border-collapse:collapse; }
.about-table th,
.about-table td { padding:16px 24px; text-align:left; border-bottom:1px solid rgba(201,160,74,.12); font-size:15px; line-height:1.7; }
.about-table tr:last-child th,
.about-table tr:last-child td { border-bottom:none; }
.about-table th { width:140px; font-weight:700; color:var(--gold); white-space:nowrap; }
.about-table td { color:var(--text); }

/* 運営者ページ本文 */
.about-body h2 { font-size:18px; font-weight:800; color:var(--gold); border-left:3px solid var(--gold); padding-left:14px; margin:36px 0 14px; }
.about-body h3 { font-size:16px; font-weight:700; margin:24px 0 10px; }
.about-body p  { font-size:15px; line-height:1.9; color:var(--text-dim); margin-bottom:16px; }
.about-body ul { padding-left:20px; margin-bottom:16px; }
.about-body ul li { font-size:15px; line-height:1.9; color:var(--text-dim); margin-bottom:4px; }

@media (max-width:600px) {
  .about-table th { width:100px; font-size:13px; padding:12px 14px; }
  .about-table td { font-size:14px; padding:12px 14px; }
}

/* スクロールアニメ（ライト） */
.page-section .fade-in { opacity:0; transform:translateY(24px); transition:opacity .6s ease,transform .6s ease; }
.page-section .fade-in.visible { opacity:1; transform:none; }

/* ライトセクション レスポンシブ */
@media (max-width:680px) {
  .section-header-row { flex-direction:column; align-items:center; gap:6px; }
  .page-section { padding:48px 0; }
}
