/*
 Theme Name: ID Affairs Theme
 Theme URI: https://example.com/
 Author: InfinityDesign
 Author URI: https://infinitydesign.online/
 Description: 成人向け・出会い系アフィリエイト（セフレ・不倫・ワンナイト・即会い）に最適化した軽量WPテーマ。CPT・タクソノミー・年齢ゲート・動的フィルタ・構造化データを内包。
 Version: 1.0.1
 License: GPL-2.0+
 Text Domain: id-affairs
 Requires at least: 5.9
 Requires PHP: 7.4
*/
:root{
  --bg:#f5f6fb;
  --bg-soft:#fdfdff;
  --card:#ffffff;
  --muted:#6b7280;
  --muted-soft:#9ca3af;
  --text:#1f2937;
  --accent:#f97316;
  --accent-2:#38bdf8;
  --ok:#22c55e;
  --danger:#ef476f;
  --border:#e5e7eb;
  --shadow:0 18px 40px rgba(31,41,55,.12);
}
*{box-sizing:border-box}
html,body{margin:0;padding:0;background:var(--bg);color:var(--text);font-family:"Helvetica Neue",system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;line-height:1.6}
a{color:var(--accent);text-decoration:none;transition:color .12s ease}
a:hover{text-decoration:none;color:#d65a0c}
.container{max-width:1100px;margin:0 auto;padding:16px}
header{background:linear-gradient(140deg,#ffffff 0%,#f8f9ff 40%,#eef5ff 100%);border-bottom:1px solid var(--border);box-shadow:0 18px 36px rgba(148,163,184,.16)}
.site-nav{display:flex;align-items:center;gap:18px;flex-wrap:wrap}
.site-nav__brand{font-weight:800;font-size:22px;color:var(--text);text-decoration:none;letter-spacing:.05em;text-transform:uppercase}
.site-nav__brand:hover{text-decoration:none;color:var(--accent)}
.site-nav__menu{list-style:none;margin:0;padding:0;display:flex;gap:14px;flex-wrap:wrap}
.site-nav__menu li{margin:0}
.site-nav__menu a{color:var(--muted);font-weight:600;font-size:14px;text-decoration:none;padding:8px 10px;border-radius:999px;transition:background .12s ease,color .12s ease}
.site-nav__menu a:hover,.site-nav__menu .current-menu-item>a{background:rgba(249,115,22,.12);color:var(--accent)}
.prefecture-menu{position:relative;margin-left:auto}
.prefecture-menu__summary{list-style:none;display:flex;align-items:center;gap:6px;padding:8px 18px;border-radius:999px;border:1px solid var(--border);background:var(--card);color:var(--text);font-size:13px;font-weight:600;cursor:pointer;box-shadow:0 8px 18px rgba(15,23,42,.08);transition:box-shadow .12s ease,border-color .12s ease}
.prefecture-menu__summary::-webkit-details-marker{display:none}
.prefecture-menu__summary:focus-visible{outline:3px solid rgba(56,189,248,.45);outline-offset:2px}
.prefecture-menu[open] .prefecture-menu__summary{border-color:#cbd5f5;box-shadow:0 18px 36px rgba(15,23,42,.16)}
.prefecture-menu__panel{position:absolute;right:0;margin-top:14px;padding:20px;border-radius:20px;border:1px solid var(--border);background:var(--bg-soft);box-shadow:0 24px 60px rgba(15,23,42,.18);width:min(360px,90vw);max-height:70vh;overflow:auto;z-index:20}
.prefecture-menu:not([open]) .prefecture-menu__panel{display:none}
.prefecture-menu__list{list-style:none;margin:0;padding:0;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}
.prefecture-menu__item{margin:0}
.prefecture-menu__link{display:block;padding:8px 12px;border-radius:999px;background:#eef2ff;border:1px solid transparent;color:#1d4ed8;font-size:13px;text-decoration:none;text-align:center;font-weight:600;transition:background .12s ease,transform .12s ease}
.prefecture-menu__link:hover{background:#dbeafe;transform:translateY(-1px)}
@media(max-width:640px){.prefecture-menu{width:100%}.prefecture-menu__panel{right:auto;left:0;width:100%}.prefecture-menu__list{grid-template-columns:repeat(3,minmax(0,1fr))}}
@media(max-width:480px){.prefecture-menu__list{grid-template-columns:repeat(2,minmax(0,1fr))}}
.grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
@media(max-width:980px){.grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:640px){.grid{grid-template-columns:1fr}}
.mama-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:16px}
.mama-card{background:var(--card);border:1px solid rgba(148,163,184,.18);border-radius:18px;overflow:hidden;box-shadow:var(--shadow);transition:transform .12s ease}
.mama-card:hover{transform:translateY(-2px)}
.mama-card a{color:inherit;text-decoration:none;display:block;height:100%}
.mama-thumb{aspect-ratio:16/9;background:#f1f5f9;display:flex;align-items:center;justify-content:center;overflow:hidden}
.mama-thumb img{display:block;width:100%;height:100%;object-fit:cover}
.mama-noimg{font-size:12px;color:#94a3b8}
.mama-meta{padding:16px}
.mama-card-title{font-size:16px;line-height:1.5;margin:0 0 6px;font-weight:700;color:var(--text)}
.mama-attrs{list-style:none;margin:0 0 8px;padding:0;font-size:13px;color:#475569}
.mama-attrs li{margin:2px 0}
.mama-attrs li strong{font-weight:700}
.mama-attrs__item--login strong{color:#0f172a}
.mama-login-status{display:inline-flex;align-items:center;gap:6px;font-weight:700;color:#047857}
.mama-login-status::before{content:"";width:8px;height:8px;border-radius:999px;background:#22c55e;box-shadow:0 0 0 4px rgba(34,197,94,.18)}
.mama-grid-note{margin:16px 4px 0;font-size:12px;color:var(--muted-soft);text-align:right}
.mama-comment{font-size:13px;color:#334155;margin:8px 0 0;line-height:1.6}
.prefecture-page__profiles .mama-grid{
  margin-top:0;
  display:grid;
  gap:16px;
  grid-template-columns:repeat(2,minmax(0,1fr));
}

@media(max-width:640px){
  .prefecture-page__profiles .mama-grid{
    grid-template-columns:1fr;
  }
}

@media(min-width:960px){
  .prefecture-page__profiles .mama-grid{
    grid-template-columns:repeat(3,minmax(0,1fr));
  }
}
.card{background:var(--card);border-radius:18px;box-shadow:var(--shadow);overflow:hidden;border:1px solid rgba(148,163,184,.18)}
.card .thumb{aspect-ratio:16/9;background:#e2e8f0;display:block}
.card .body{padding:18px}
.badges{display:flex;flex-wrap:wrap;gap:8px;margin:8px 0}
.badge{padding:4px 10px;border-radius:999px;font-size:12px;background:#eef2ff;color:#3730a3;font-weight:600}
.badge.ok{background:rgba(34,197,94,.12);color:#166534}
.badge.warn{background:rgba(249,115,22,.12);color:#9a3412}
.badge.danger{background:rgba(239,71,111,.15);color:#a11a3d}
.filters{display:flex;flex-wrap:wrap;gap:10px;margin:10px 0 16px}
select,input[type="search"],button{background:var(--card);color:var(--text);border:1px solid var(--border);border-radius:12px;padding:9px 12px;box-shadow:0 6px 16px rgba(15,23,42,.06)}
select:focus,input[type="search"]:focus,button:focus{outline:3px solid rgba(56,189,248,.35);outline-offset:2px}
button.cta{background:var(--accent);border:none;color:white;font-weight:700;cursor:pointer;box-shadow:0 14px 30px rgba(249,115,22,.25)}
button.cta:hover{opacity:.92}
.hero{padding:36px 0 24px}
.hero h1{margin:0 0 10px;font-size:30px;color:var(--text)}
.hero p{margin:0;color:var(--muted)}
.column-hero{padding:48px 0 24px;text-align:center}
.column-hero__eyebrow{display:inline-flex;align-items:center;justify-content:center;padding:6px 16px;border-radius:999px;background:rgba(56,189,248,.16);color:#0c4a6e;font-size:12px;font-weight:700;letter-spacing:.14em;margin:0 0 16px;text-transform:uppercase}
.column-hero__title{margin:0 0 12px;font-size:clamp(30px,4vw,42px);letter-spacing:.04em;color:#0f172a;font-weight:800}
.column-hero__lead{margin:0 auto;max-width:680px;color:#475569;font-size:16px;line-height:1.8}
.column-archive{margin:0 0 72px}
.column-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:24px}
.column-card{background:var(--card);border-radius:24px;overflow:hidden;box-shadow:0 24px 64px rgba(15,23,42,.14);border:1px solid rgba(148,163,184,.14);display:flex;flex-direction:column;transition:transform .16s ease,box-shadow .16s ease}
.column-card:hover{transform:translateY(-4px);box-shadow:0 28px 72px rgba(15,23,42,.18)}
.column-card__thumb{display:block;position:relative;overflow:hidden}
.column-card__image{display:block;width:100%;height:100%;object-fit:cover;aspect-ratio:16/10}
.column-card__image--fallback{display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#eff6ff 0%,#dbeafe 100%);padding:18px;font-weight:700;color:#1d4ed8;text-align:center}
.column-card__body{padding:22px 22px 26px;display:flex;flex-direction:column;gap:14px}
.column-card__meta{display:flex;flex-wrap:wrap;gap:10px;font-size:13px;color:#64748b}
.column-card__categories{display:flex;flex-wrap:wrap;gap:8px}
.column-card__category{color:#1d4ed8;font-weight:600;font-size:12px;padding:4px 10px;border-radius:999px;background:rgba(37,99,235,.1)}
.column-card__category:hover{background:rgba(37,99,235,.18)}
.column-card__title{margin:0;font-size:18px;line-height:1.5;color:#0f172a;font-weight:700}
.column-card__title a{color:inherit;text-decoration:none}
.column-card__title a:hover{text-decoration:underline}
.column-card__excerpt{margin:0;color:#475569;font-size:14px;line-height:1.7}
.column-card__more{align-self:flex-start;margin-top:auto;padding:8px 16px;border-radius:999px;background:#f1f5f9;color:#1f2937;font-weight:600;font-size:13px;transition:background .16s ease,transform .16s ease}
.column-card__more:hover{background:#e2e8f0;transform:translateY(-1px)}
.column-archive__pagination{margin:40px 0 0;display:flex;justify-content:center}
.column-archive__pagination .page-numbers{display:inline-flex;align-items:center;justify-content:center;width:42px;height:42px;margin:0 4px;border-radius:12px;background:var(--card);border:1px solid rgba(148,163,184,.24);color:#0f172a;font-weight:600;box-shadow:0 12px 28px rgba(15,23,42,.12);transition:background .12s ease,color .12s ease,transform .12s ease}
.column-archive__pagination .page-numbers.current{background:#2563eb;color:#fff;border-color:#2563eb}
.column-archive__pagination .page-numbers:hover{transform:translateY(-2px)}
.column-archive__empty{margin:0;padding:32px;border-radius:20px;background:#f8fafc;border:1px dashed rgba(148,163,184,.6);color:#475569;text-align:center}

.column-article{max-width:760px;margin:0 auto 90px;background:var(--card);border-radius:30px;padding:48px 56px;box-shadow:0 32px 80px rgba(15,23,42,.16);border:1px solid rgba(148,163,184,.16)}
.column-article__header{text-align:center;margin:0 0 26px}
.column-article__eyebrow{display:inline-flex;align-items:center;justify-content:center;padding:6px 16px;border-radius:999px;background:rgba(249,115,22,.12);color:#9a3412;font-size:12px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;margin:0 0 16px}
.column-article__title{margin:0 0 16px;font-size:clamp(28px,4.2vw,44px);color:#0f172a;line-height:1.35}
.column-article__meta{display:flex;justify-content:center;align-items:center;gap:12px;color:#64748b;font-size:13px;flex-wrap:wrap}
.column-article__categories{display:flex;flex-wrap:wrap;gap:8px}
.column-article__category{color:#1d4ed8;font-weight:600;font-size:12px;padding:4px 10px;border-radius:999px;background:rgba(37,99,235,.1)}
.column-article__category:hover{background:rgba(37,99,235,.18)}
.column-article__figure{margin:0 -12px 26px;border-radius:24px;overflow:hidden;box-shadow:0 24px 64px rgba(15,23,42,.16)}
.column-article__figure img{display:block;width:100%;height:auto}
.column-article__figure figcaption{margin:0;padding:12px 18px;background:#f1f5f9;color:#475569;font-size:12px}
.column-article__content{font-size:16px;color:#1f2937;line-height:1.9}
.column-article__content h2{margin:32px 0 16px;font-size:24px;color:#0f172a}
.column-article__content h3{margin:26px 0 12px;font-size:20px;color:#1f2937}
.column-article__content p{margin:0 0 18px}
.column-article__content ul,.column-article__content ol{margin:0 0 22px 1.4em;padding:0;color:#1f2937}
.column-article__content blockquote{margin:28px 0;padding:24px;border-left:4px solid #2563eb;background:#eff6ff;border-radius:0 18px 18px 0;color:#1d4ed8;font-style:italic}
.column-article__footer{margin:40px 0 0;border-top:1px solid rgba(148,163,184,.28);padding-top:26px;display:flex;flex-direction:column;gap:18px}
.column-article__keywords{display:flex;flex-wrap:wrap;gap:10px}
.column-article__tag{display:inline-flex;align-items:center;justify-content:center;padding:6px 12px;border-radius:999px;background:#f1f5f9;color:#1f2937;font-size:12px;font-weight:600}
.column-article__pager .nav-sub{display:block;font-size:12px;color:#94a3b8;letter-spacing:.12em;text-transform:uppercase;margin-bottom:6px}
.column-article__pager .nav-title{display:block;font-size:15px;color:#1f2937;font-weight:700}
.column-article__pager a{display:block;padding:16px 18px;border-radius:18px;border:1px solid rgba(148,163,184,.24);margin:6px 0;background:var(--bg-soft);transition:transform .12s ease,box-shadow .12s ease}
.column-article__pager a:hover{transform:translateY(-2px);box-shadow:0 16px 36px rgba(15,23,42,.12)}

.wysiwyg img{max-width:100%;height:auto;border-radius:16px}
.wysiwyg table{width:100%;border-collapse:collapse;margin:24px 0}
.wysiwyg table th,.wysiwyg table td{border:1px solid rgba(148,163,184,.35);padding:12px;text-align:left}
.wysiwyg a{text-decoration:underline}

@media(max-width:960px){
  .column-article{padding:42px 40px;margin-bottom:70px}
}

@media(max-width:720px){
  .column-grid{grid-template-columns:repeat(auto-fill,minmax(240px,1fr))}
  .column-card__body{padding:20px}
  .column-article{padding:32px 28px;border-radius:26px}
  .column-article__figure{margin:0 0 24px}
}

@media(max-width:560px){
  .column-hero{padding:32px 0 16px}
  .column-hero__title{font-size:28px}
  .column-grid{grid-template-columns:1fr}
  .column-card__image{aspect-ratio:16/9}
  .column-card__body{gap:12px}
  .column-article{padding:26px 22px;margin-bottom:56px}
  .column-article__title{font-size:26px}
  .column-article__content{font-size:15px}
}
.footer{border-top:1px solid var(--border);margin-top:60px;padding:32px 0;background:#f1f5f9;color:var(--muted)}
#age-gate{position:fixed;inset:0;background:rgba(248,250,255,.85);backdrop-filter:blur(12px);display:none;z-index:9999;align-items:center;justify-content:center}
#age-gate .box{background:var(--card);border:1px solid var(--border);border-radius:20px;padding:28px;max-width:520px;width:92%;box-shadow:0 24px 60px rgba(15,23,42,.16)}
#age-gate h2{margin:0 0 8px;font-size:24px}
#age-gate p{color:var(--muted);margin:0 0 20px}
#age-gate .row{display:flex;gap:12px;justify-content:flex-end}
#notice{font-size:12px;color:var(--muted-soft);margin-top:6px}
.table{width:100%;border-collapse:separate;border-spacing:0 8px}
.table th,.table td{padding:12px 14px;background:var(--card);border:1px solid var(--border)}
.table th{background:#f1f5f9;color:#475569;text-align:left;font-weight:700}
.table tr td:first-child,.table tr th:first-child{border-top-left-radius:12px;border-bottom-left-radius:12px}
.table tr td:last-child,.table tr th:last-child{border-top-right-radius:12px;border-bottom-right-radius:12px}
.cta-box{background:linear-gradient(135deg,#fff5eb 0%,#ffe0c6 55%,#ffd0b5 100%);border:1px solid rgba(249,115,22,.2);border-radius:18px;padding:18px;margin:22px 0;box-shadow:0 20px 40px rgba(249,115,22,.15)}
.cta-title{font-weight:700;margin:0 0 8px;color:#9a3412}
.small{font-size:12px;color:var(--muted-soft)}
.prefecture-page__wrapper{max-width:960px;margin:0 auto;padding:48px 16px}
.prefecture-page{background:var(--card);border-radius:28px;padding:36px;box-shadow:var(--shadow);border:1px solid rgba(148,163,184,.22)}
.prefecture-page__header{margin-bottom:30px;text-align:center}
.prefecture-page__title{margin:0 0 12px;font-size:32px;letter-spacing:.04em;color:var(--text)}
.prefecture-page__lead{margin:0;color:var(--muted);font-size:17px}
.prefecture-page__placeholder{margin:-8px 0 32px;padding:18px 22px;border-radius:18px;background:#fff7ed;border:1px solid rgba(249,115,22,.35);color:#b45309;font-size:14px;line-height:1.7;box-shadow:0 12px 26px rgba(249,115,22,.12)}
.prefecture-page__placeholder code{background:#fde68a;padding:2px 6px;border-radius:6px;color:#78350f}
.prefecture-page__stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:16px;margin:0 0 28px;padding:0}
.prefecture-page__stat{background:#f8fafc;padding:18px;border-radius:18px;border:1px solid var(--border);text-align:center;box-shadow:0 10px 24px rgba(148,163,184,.16)}
.prefecture-page__stat-label{margin:0;color:var(--muted);font-size:12px;text-transform:uppercase;letter-spacing:.08em}
.prefecture-page__stat-value{margin:6px 0 0;font-size:22px;font-weight:700;color:#0f172a}
.prefecture-page__section{margin:0 0 36px}
.prefecture-page__section-title{margin:0 0 16px;font-size:22px;color:#0f172a}
.prefecture-page__section-content{color:#475569;font-size:15px}
.prefecture-page__figure{margin:22px 0;border-radius:18px;overflow:hidden;background:#f1f5f9;border:1px solid var(--border);box-shadow:0 16px 32px rgba(15,23,42,.12)}
.prefecture-page__figure img{display:block;width:100%;height:auto}
.prefecture-page__caption{margin:0;padding:10px 14px;color:#64748b;font-size:13px;background:#e2e8f0}
.prefecture-page__list{list-style:none;margin:18px 0 0;padding:0;display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:14px}
.prefecture-page__list-item{margin:0;padding:16px;border-radius:16px;background:#f8fafc;border:1px solid var(--border);color:#0f172a;font-size:14px;box-shadow:0 12px 24px rgba(148,163,184,.12)}
.prefecture-page__link{color:#2563eb;font-weight:600}
.prefecture-page__cta{margin:32px 0 0}
.prefecture-page__cta-list{list-style:none;margin:0;padding:0;display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px}
.prefecture-page__cta-item{margin:0;padding:18px;border-radius:20px;background:#eff6ff;border:1px solid rgba(37,99,235,.2);box-shadow:0 16px 32px rgba(37,99,235,.18)}
.prefecture-page__cta-link{display:inline-block;font-weight:700;color:#1d4ed8}
.prefecture-page__cta-description{margin:8px 0 0;color:#334155;font-size:13px}
.prefecture-page__meta{margin:40px 0 0;padding:24px;border-radius:18px;background:#f8fafc;border:1px solid var(--border)}
.prefecture-page__meta-list{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:14px;margin:0;padding:0;list-style:none}
.prefecture-page__meta-item{margin:0;padding:14px 16px;border-radius:14px;background:#fff;border:1px solid var(--border);box-shadow:0 10px 22px rgba(148,163,184,.14)}
.prefecture-page__meta-label{margin:0 0 4px;color:var(--muted);font-size:12px;letter-spacing:.04em;text-transform:uppercase}
.prefecture-page__meta-value{margin:0;color:#0f172a;font-size:14px;word-break:break-all}
.prefecture-page__profiles{margin:0 0 40px}
.prefecture-page__profiles-title{text-align:center;margin:0 0 12px}
.prefecture-page__profiles-summary{margin:0 0 24px;text-align:center;color:var(--muted);font-size:14px}
.prefecture-page__profiles--empty{padding:32px;border-radius:18px;background:#f8fafc;border:1px dashed rgba(148,163,184,.6);text-align:center}
.prefecture-page__profiles--empty .prefecture-page__profiles-summary{margin:12px 0 0}
@media(max-width:720px){
  .prefecture-page{padding:28px}
  .prefecture-page__title{font-size:28px}
  .prefecture-page__list{grid-template-columns:repeat(auto-fit,minmax(160px,1fr))}
  .prefecture-page__cta-list{grid-template-columns:repeat(auto-fit,minmax(180px,1fr))}
}
.mamapref{max-width:960px;margin:56px auto 88px;padding:42px 52px;border-radius:26px;background:linear-gradient(150deg,#ffffff 0%,#f8f9ff 50%,#eef2ff 100%);box-shadow:0 26px 54px -28px rgba(26,48,94,.45)}
.mamapref h1{margin:0 0 26px;font-size:clamp(26px,3.1vw,34px);line-height:1.32;font-weight:700;color:#1f2f4d;text-align:center;letter-spacing:.03em}
.mamapref .meta-description{margin:0 auto 44px;max-width:760px;font-size:16px;line-height:1.9;color:#435068;text-align:center;background:#fff;border-left:4px solid #5a6fea;padding:18px 22px;border-radius:14px;box-shadow:0 12px 30px -28px rgba(30,46,90,.35)}
.mamapref section{margin:0 0 38px;padding-bottom:30px;border-bottom:1px solid rgba(60,80,130,.18)}
.mamapref section:last-of-type{border-bottom:none;padding-bottom:0;margin-bottom:0}
.mamapref h2{margin:0 0 18px;font-size:clamp(20px,2.6vw,26px);color:#2b3a63;font-weight:700;position:relative;padding-left:18px;letter-spacing:.02em}
.mamapref h2::before{content:"";position:absolute;left:0;top:12px;width:6px;height:28px;border-radius:999px;background:linear-gradient(170deg,#5c7bff,#41d2ff)}
.mamapref h3{margin:22px 0 14px;font-size:18px;color:#3c4b6d;font-weight:600;display:flex;align-items:center;gap:10px}
.mamapref p{margin:0;font-size:16px;line-height:1.95;color:#455066}
.mamapref ul,.mamapref ol{margin:0;padding-left:22px;color:#3d4762;line-height:1.85}
.mamapref li{margin:6px 0}
.mamapref-highlights{list-style:none;padding:0;margin:0;display:grid;gap:14px}
.mamapref-highlights li{margin:0;padding:16px 18px;border-radius:16px;background:rgba(255,255,255,.88);box-shadow:0 20px 46px -38px rgba(31,49,94,.45);border:1px solid rgba(92,123,255,.12)}
.mamapref blockquote{margin:18px 0;padding:22px 24px;border-left:4px solid rgba(90,110,234,.6);background:rgba(255,255,255,.88);border-radius:14px;color:#3b4561;font-style:normal;line-height:1.85;box-shadow:0 18px 42px -36px rgba(32,46,88,.45)}
.prefecture-page__section .mamapref{margin:12px 0 0;padding:0;background:none;box-shadow:none}
.prefecture-page__section .mamapref h1{text-align:left;font-size:clamp(24px,3vw,32px);margin-bottom:22px}
.prefecture-page__section .mamapref .meta-description{max-width:none;text-align:left}
.prefecture-page__section .mamapref section{border-bottom:none;padding-bottom:0;margin-bottom:28px}
.prefecture-ranking{margin:22px 0 0}
.ranking-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:22px}
.ranking-grid--prefecture{margin-top:18px}
.ranking-grid--page{margin-top:26px}
.ranking-card{position:relative;display:flex;flex-direction:column;background:var(--card);border-radius:24px;border:1px solid rgba(148,163,184,.18);box-shadow:0 28px 68px rgba(15,23,42,.16);overflow:hidden;transition:transform .16s ease,box-shadow .16s ease}
.ranking-card:hover{transform:translateY(-4px);box-shadow:0 32px 80px rgba(15,23,42,.2)}
.ranking-card__badge{position:absolute;top:16px;left:16px;padding:6px 14px;border-radius:999px;background:linear-gradient(135deg,#f97316,#fb923c);color:#fff;font-weight:700;font-size:12px;letter-spacing:.08em;text-transform:uppercase;box-shadow:0 12px 26px rgba(249,115,22,.35)}
.ranking-card__media{position:relative;overflow:hidden}
.ranking-card__media a{display:block}
.ranking-card__image{display:block;width:100%;height:auto;object-fit:cover;aspect-ratio:16/10}
.ranking-card__image--placeholder{display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#eff6ff 0%,#dbeafe 100%);color:#1d4ed8;font-weight:600;font-size:14px;letter-spacing:.08em}
.ranking-card__body{padding:24px 24px 28px;display:flex;flex-direction:column;gap:16px}
.ranking-card__pref{display:inline-flex;align-items:center;justify-content:center;align-self:flex-start;padding:4px 12px;border-radius:999px;background:rgba(56,189,248,.18);color:#0369a1;font-size:12px;font-weight:700;letter-spacing:.08em;text-transform:uppercase}
.ranking-card__title{margin:0;font-size:20px;line-height:1.5;color:#0f172a;font-weight:700}
.ranking-card__summary{font-size:14px;line-height:1.8;color:#475569;display:flex;flex-direction:column;gap:10px}
.ranking-card__summary p{margin:0}
.ranking-card__cta{align-self:flex-start;padding:10px 20px;border-radius:999px;background:linear-gradient(135deg,#2563eb,#38bdf8);color:#fff;font-weight:700;font-size:13px;text-decoration:none;box-shadow:0 18px 32px rgba(37,99,235,.25);transition:transform .16s ease,box-shadow .16s ease}
.ranking-card__cta:hover{transform:translateY(-2px);box-shadow:0 24px 40px rgba(37,99,235,.3)}
.ranking-page{padding:48px 0 80px}
.ranking-hero{text-align:center;margin:0 0 48px}
.ranking-hero__eyebrow{display:inline-flex;align-items:center;justify-content:center;padding:6px 16px;border-radius:999px;background:rgba(37,99,235,.15);color:#1d4ed8;font-size:12px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;margin:0 0 16px}
.ranking-hero__title{margin:0 0 16px;font-size:clamp(32px,4.2vw,46px);color:#0f172a;font-weight:800;letter-spacing:.02em}
.ranking-hero__lead{margin:0 auto;max-width:720px;color:#475569;font-size:16px;line-height:1.9}
.ranking-directory{display:flex;flex-direction:column;gap:54px}
.ranking-section{padding:32px 34px;border-radius:28px;background:linear-gradient(140deg,#ffffff 0%,#f5f7ff 55%,#eef2ff 100%);box-shadow:0 28px 72px rgba(15,23,42,.12);border:1px solid rgba(148,163,184,.16)}
.ranking-section__header{display:flex;flex-wrap:wrap;align-items:center;gap:14px;justify-content:space-between;margin:0 0 24px}
.ranking-section__title{margin:0;font-size:clamp(22px,2.6vw,28px);color:#1f2f4d;font-weight:700}
.ranking-section__intro{margin:0;color:#47516b;font-size:clamp(15px,2vw,17px);line-height:1.7;flex-basis:100%}
.ranking-section__link{font-size:13px;font-weight:700;color:#2563eb;text-decoration:none;padding:8px 16px;border-radius:999px;background:rgba(37,99,235,.14);transition:background .16s ease,transform .16s ease}
.ranking-section__link:hover{background:rgba(37,99,235,.24);transform:translateY(-2px)}
.ranking-empty{margin:0;padding:48px;border-radius:24px;text-align:center;background:#f8fafc;border:1px dashed rgba(148,163,184,.6);color:#475569}
.u-hide-sm{display:inline}

@media(max-width:960px){
  .ranking-directory{gap:42px}
  .ranking-section{padding:28px 24px}
  .ranking-card__body{padding:22px 20px 26px}
}

@media(max-width:720px){
  .ranking-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:20px}
  .ranking-card__title{font-size:18px}
  .ranking-card__summary{font-size:13px}
}

@media(max-width:560px){
  .ranking-page{padding:32px 0 56px}
  .ranking-hero{margin-bottom:36px}
  .ranking-hero__title{font-size:28px}
  .ranking-hero__lead{font-size:15px}
  .ranking-section{padding:24px 18px}
  .ranking-section__title{font-size:20px}
  .ranking-grid{grid-template-columns:1fr}
  .ranking-card__body{padding:20px 18px 22px}
  .ranking-card__badge{top:12px;left:12px}
  .ranking-card__cta{width:100%;text-align:center}
  .u-hide-sm{display:none}
}
.prefecture-nav{max-width:1100px;margin:48px auto 0;padding:32px 36px;border-radius:28px;background:linear-gradient(145deg,#ffffff 0%,#f6f7ff 50%,#eef4ff 100%);border:1px solid rgba(148,163,184,.22);box-shadow:0 28px 64px -36px rgba(30,41,59,.48)}
.prefecture-nav__title{margin:0 0 22px;font-size:clamp(20px,2.4vw,26px);font-weight:700;color:#1e293b;letter-spacing:.03em;position:relative;padding-left:20px}
.prefecture-nav__title::before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:6px;height:32px;border-radius:999px;background:linear-gradient(165deg,#f97316,#38bdf8)}
.prefecture-nav__select{display:none;margin:0 0 18px}
.prefecture-nav__select-label{position:absolute;clip:rect(1px,1px,1px,1px);padding:0;border:0;height:1px;width:1px;overflow:hidden;white-space:nowrap}
.prefecture-nav__select-control{width:100%;padding:12px 18px;border-radius:999px;border:1px solid rgba(148,163,184,.25);background:#ffffff;font-size:14px;font-weight:600;color:#1f2937;box-shadow:0 18px 38px -30px rgba(30,41,59,.45);appearance:none;-webkit-appearance:none;-moz-appearance:none;background-image:url('data:image/svg+xml,%3Csvg width="12" height="8" viewBox="0 0 12 8" xmlns="http://www.w3.org/2000/svg"%3E%3Cpath d="M1 1.5L6 6.5L11 1.5" stroke="%23343F5E" stroke-width="1.6" stroke-linecap="round" stroke-linejoin="round"/%3E%3C/svg%3E');background-repeat:no-repeat;background-position:right 16px center;background-size:12px auto;cursor:pointer}
.prefecture-nav__select-control:focus{outline:none;box-shadow:0 0 0 3px rgba(56,189,248,.35)}
.prefecture-nav__list{list-style:none;margin:0;padding:0;display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:14px}
.prefecture-nav__item{margin:0}
.prefecture-nav__link{display:flex;align-items:center;justify-content:center;padding:12px 18px;border-radius:999px;background:#ffffff;border:1px solid rgba(148,163,184,.2);font-size:14px;font-weight:600;color:#1f2937;text-decoration:none;box-shadow:0 18px 38px -30px rgba(30,41,59,.5);transition:transform .16s ease,box-shadow .16s ease,background .16s ease,color .16s ease}
.prefecture-nav__link:focus-visible{outline:3px solid rgba(56,189,248,.45);outline-offset:3px}
@media (hover:hover){.prefecture-nav__link:hover{transform:translateY(-3px);box-shadow:0 24px 46px -32px rgba(30,41,59,.55);background:linear-gradient(120deg,rgba(249,115,22,.14),rgba(56,189,248,.14));color:var(--accent)}}
.mamaktips{max-width:1000px;margin:60px auto 110px;padding:48px clamp(22px,5vw,54px);border-radius:32px;background:linear-gradient(160deg,#ffffff 0%,#f6f7ff 55%,#eef4ff 100%);border:1px solid rgba(148,163,184,.2);box-shadow:0 34px 70px -40px rgba(15,23,42,.4)}
.mamaktips h1{margin:0 0 28px;font-size:clamp(28px,3.4vw,36px);line-height:1.32;font-weight:700;color:#1f2a44;text-align:center;letter-spacing:.03em}
.mamaktips .meta-description{margin:0 auto 44px;max-width:780px;font-size:16px;line-height:1.9;color:#3f4a66;text-align:center;background:#ffffff;border-radius:16px;padding:20px 24px;border-left:4px solid rgba(90,110,234,.6);box-shadow:0 20px 42px -34px rgba(48,58,102,.55)}
.mamaktips section{margin:0 0 40px;padding-bottom:32px;border-bottom:1px solid rgba(71,85,105,.16)}
.mamaktips section:last-of-type{border-bottom:none;padding-bottom:0;margin-bottom:0}
.mamaktips h2{margin:0 0 18px;font-size:clamp(22px,2.6vw,28px);color:#273759;font-weight:700;position:relative;padding-left:20px;letter-spacing:.02em}
.mamaktips h2::before{content:"";position:absolute;left:0;top:11px;width:6px;height:30px;border-radius:999px;background:linear-gradient(165deg,#5a6fea,#41d2ff)}
.mamaktips h3{margin:24px 0 14px;font-size:18px;color:#36415d;font-weight:600;display:flex;align-items:center;gap:10px}
.mamaktips ul,.mamaktips ol{margin:0;padding-left:24px;color:#3b4358;line-height:1.85}
.mamaktips li{margin:6px 0}
.mamaktips blockquote{margin:18px 0;padding:22px 24px;border-left:4px solid rgba(90,110,234,.55);background:rgba(255,255,255,.92);border-radius:16px;color:#3a435c;line-height:1.85;box-shadow:0 22px 48px -36px rgba(35,46,84,.5)}
.mamaktips p{margin:0;font-size:16px;line-height:1.95;color:#414b63}
.user-voice-block{max-width:1000px;margin:56px auto;padding:40px clamp(20px,4vw,52px);border-radius:30px;background:linear-gradient(155deg,#ffffff 0%,#f6f7ff 50%,#eef4ff 100%);border:1px solid rgba(148,163,184,.22);box-shadow:0 28px 64px -36px rgba(15,23,42,.46)}
.user-voice-block__title{margin:0;font-size:clamp(24px,3vw,32px);font-weight:700;color:#1f2a44;letter-spacing:.03em;text-align:center}
.user-voice-block__intro{margin:16px auto 0;max-width:720px;color:#64748b;font-size:15px;line-height:1.9;text-align:center}
.user-voice-block__grid{margin:32px 0 0;padding:0;display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:20px;list-style:none}
.user-voice-card{background:var(--card);border:1px solid rgba(148,163,184,.2);border-radius:22px;padding:24px;box-shadow:var(--shadow);display:flex;flex-direction:column;gap:16px;min-height:100%;transition:transform .16s ease,box-shadow .16s ease}
.user-voice-card:hover{transform:translateY(-2px);box-shadow:0 28px 54px -36px rgba(15,23,42,.38)}
.user-voice-card__header{display:flex;justify-content:space-between;align-items:center;gap:12px}
.user-voice-card__identity{display:flex;align-items:center;gap:8px;font-weight:700;color:var(--text);font-size:15px}
.user-voice-card__age{font-size:13px;color:var(--muted);font-weight:600}
.user-voice-card__pref{display:inline-flex;align-items:center;gap:6px;padding:6px 14px;border-radius:999px;background:#eef2ff;color:#1d4ed8;font-weight:700;font-size:12px;box-shadow:0 12px 26px rgba(37,99,235,.18)}
.user-voice-card__comment{margin:0;color:#334155;font-size:14px;line-height:1.85}
.user-voice-card__comment-prefix{display:block;font-weight:700;color:#1d4ed8;margin-bottom:6px;font-size:13px;letter-spacing:.02em}
.user-voice-card__comment-body{display:block}
.user-voice-card--slider{height:100%}
.user-voice-slider{max-width:1100px;margin:48px auto 72px;padding:38px clamp(20px,4vw,44px);border-radius:32px;background:linear-gradient(150deg,#ffffff 0%,#f5f7ff 55%,#eef5ff 100%);border:1px solid rgba(148,163,184,.22);box-shadow:0 34px 72px -42px rgba(15,23,42,.45)}
.user-voice-slider__header{display:flex;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;margin-bottom:20px}
.user-voice-slider__titles{flex:1 1 320px;min-width:0}
.user-voice-slider__title{margin:0;font-size:clamp(22px,3vw,30px);font-weight:700;color:#1f2a44;letter-spacing:.03em}
.user-voice-slider__subtitle{margin:4px 0 0;color:#64748b;font-size:14px;line-height:1.7}
.user-voice-slider__controls{display:flex;gap:12px}
.user-voice-slider__btn{width:46px;height:46px;border-radius:50%;border:1px solid rgba(148,163,184,.35);background:var(--card);color:#1f2937;display:flex;align-items:center;justify-content:center;box-shadow:0 16px 32px rgba(15,23,42,.2);cursor:pointer;transition:background .16s ease,color .16s ease,transform .16s ease}
.user-voice-slider__btn span{font-size:22px;line-height:1}
.user-voice-slider__btn:hover{background:var(--accent);color:#fff;transform:translateY(-2px)}
.user-voice-slider__btn:disabled{opacity:.35;cursor:not-allowed;transform:none}
.user-voice-slider__viewport{overflow-x:auto;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;padding-bottom:6px;margin:0 -6px}
.user-voice-slider__viewport::-webkit-scrollbar{height:8px}
.user-voice-slider__viewport::-webkit-scrollbar-thumb{background:rgba(148,163,184,.45);border-radius:999px}
.user-voice-slider__viewport::-webkit-scrollbar-track{background:rgba(226,232,240,.6);border-radius:999px}
.user-voice-slider__track{display:flex;gap:18px;min-width:100%;padding:4px}
.user-voice-slider__item{flex:0 0 82%;scroll-snap-align:start}
@media(max-width:960px){
  .prefecture-nav{margin:40px 16px 0;padding:28px 26px;border-radius:24px}
}
@media(max-width:720px){
  .prefecture-nav__select{display:block}
  .prefecture-nav__list{display:none}
  .mamaktips{margin:48px 16px 90px;padding:40px 24px;border-radius:26px}
  .mamaktips .meta-description{padding:18px 20px;font-size:15px}
  .mamaktips h2{padding-left:16px}
  .mamaktips h2::before{width:4px;height:26px;top:10px}
  .mamaktips ul,.mamaktips ol{padding-left:20px}
  .user-voice-block{margin:44px 16px;padding:32px 24px;border-radius:26px}
  .user-voice-block__intro{font-size:14px}
  .user-voice-slider{margin:38px 16px 56px;padding:32px 22px}
  .user-voice-slider__controls{width:100%;justify-content:flex-end}
}
@media(max-width:520px){
  .prefecture-nav{padding:24px 20px}
  .prefecture-nav__title{padding-left:16px}
  .prefecture-nav__title::before{width:4px;height:26px}
  .prefecture-nav__link{padding:11px 16px;font-size:13px}
  .mamaktips{padding:36px 20px;border-radius:22px}
  .mamaktips h1{font-size:clamp(24px,7vw,30px)}
  .user-voice-block__grid{grid-template-columns:1fr}
  .user-voice-slider__item{flex-basis:90%}
  .user-voice-slider__title{font-size:24px}
}
.prefecture-page__section .mamapref section:last-of-type{margin-bottom:0}
@media(min-width:640px){
  .user-voice-slider__item{flex-basis:48%}
}
@media(min-width:960px){
  .user-voice-slider__item{flex-basis:32%}
}
@media(max-width:768px){
  .mamapref{padding:34px 24px;border-radius:22px;margin:48px auto 70px}
  .mamapref .meta-description{padding:16px 18px;font-size:15px}
  .mamapref h2{padding-left:16px}
  .mamapref h2::before{width:4px;height:24px;top:10px}
  .mamapref ul,.mamapref ol{padding-left:20px}
}

.content-article {
    background-color: white;
    padding: 40px;
    border-radius: 8px;
    box-shadow: 0 0 20px rgba(0, 0, 0, 0.05);
}
/* 6. 特殊なボックス */
.note-box {
    background-color: #ecf0f1;
    border-left: 4px solid #bdc3c7;
    padding: 15px;
    margin: 20px 0;
    border-radius: 4px;
}

.note-box.danger {
    background-color: #fbecec;
    border-left-color: #e74c3c;
    color: #c0392b;
}

/* 7. テーブル（データ構造化） */
.styled-table {
    width: 100%;
    border-collapse: collapse;
    margin: 20px 0;
    font-size: 0.95em;
    text-align: left;
}

.styled-table thead tr {
    background-color: #4a90e2;
    color: white;
}

.styled-table th,
.styled-table td {
    padding: 12px 15px;
    border: 1px solid #ddd;
}

.styled-table tbody tr:nth-of-type(even) {
    background-color: #f3f3f3;
}

.styled-table tbody tr:hover {
    background-color: #f1f1f1;
}

/* 8. 拡張コンテンツの強調 */
.expansion-point {
    border: 1px solid #4a90e2;
    padding: 20px;
    margin-top: 30px;
    border-radius: 6px;
    background-color: #f9fbfd;
}

.expansion-point h3 {
    color: #4a90e2;
    border-bottom: none;
    margin-top: 0;
}

/* 9. リストの装飾 */
.checklist, .talk-tips, .legal-notes {
    list-style: none;
    padding-left: 0;
}

.checklist li, .talk-tips li, .legal-notes li {
    background: #e8f5e9;
    padding: 10px 15px;
    margin-bottom: 10px;
    border-radius: 4px;
    position: relative;
    padding-left: 40px;
}

.checklist li::before, .talk-tips li::before, .legal-notes li::before {
    content: '✓';
    position: absolute;
    left: 15px;
    color: #27ae60; /* チェックマークの色 */
    font-weight: bold;
}

.danger-list li {
    background: #fbecec;
}

.danger-list li::before {
    content: '⚠';
    color: #e74c3c; /* 警告マークの色 */
}

/* 10. フッター */
footer {
    text-align: center;
    padding: 20px 0;
    background-color: #34495e;
    color: #ecf0f1;
    font-size: 0.9em;
    margin-top: 40px;
}

/* 11. レスポンシブデザイン */
@media (max-width: 768px) {
    header h1 {
        font-size: 1.8em;
    }

    h2 {
        font-size: 1.5em;
    }

    h3 {
        font-size: 1.2em;
    }

    .content-article {
        padding: 20px;
    }

    .styled-table th,
    .styled-table td {
        padding: 8px 10px;
        display: block; /* モバイルで縦に並べる */
        width: 100%;
    }

    .styled-table thead {
        display: none; /* ヘッダーを非表示 */
    }

    .styled-table tr {
        margin-bottom: 15px;
        border: 1px solid #ddd;
        display: block;
    }

    .styled-table td::before {
        /* データラベルを表示 */
        content: attr(data-label);
        font-weight: bold;
        display: inline-block;
        width: 120px;
        margin-right: 10px;
    }
}

/* 12. 拡張コンテンツ（深掘り戦略）のスタイル */
.deep-strategy h2 {
    color: #2980b9; /* 拡張セクションのH2を少し違う色に */
    border-left-color: #2980b9;
}

.success-story h3, .regional-strategy h3, .mental-strategy h3 {
    color: #2980b9;
}

/* 属性別攻略のリストスタイル */
.attribute-tips li {
    background: #f0f8ff; /* 薄い青の背景 */
    border-left: 5px solid #3498db;
    padding: 10px 15px;
    margin-bottom: 10px;
    list-style: none;
    position: relative;
    padding-left: 15px;
}

.attribute-tips li strong {
    color: #e67e22; /* 強調キーワードの色を変更 */
}

/* メンタルリストのスタイル */
.mental-list {
    list-style: none;
    padding-left: 0;
}

.mental-list li {
    background: #fcf8e3; /* 警告色に近い薄い黄色 */
    border-left: 5px solid #f39c12;
    padding: 10px 15px;
    margin-bottom: 10px;
    position: relative;
    padding-left: 15px;
}

/* テーブルのモバイル対応（data-labelの追加） */
@media (max-width: 768px) {
    .styled-table td::before {
        /* data-labelの幅を調整 */
        width: 140px;
    }
}

/* ========================================
   都道府県別ママ活ガイド - 新セクションスタイル (v3)
   ======================================== */

/* メインセクション */
.mamapref-section {
  margin: 48px 0;
  padding: 0;
  background: transparent;
  border-radius: 0;
  border: none;
  box-shadow: none;
}

.mamapref-section h2 {
  margin: 0 0 32px;
  font-size: clamp(24px, 2.8vw, 32px);
  color: #0f172a;
  font-weight: 800;
  letter-spacing: -0.03em;
  border-bottom: none;
  padding-bottom: 0;
  position: relative;
}

.mamapref-section h2::after {
  content: "";
  display: block;
  width: 80px;
  height: 5px;
  background: linear-gradient(90deg, var(--accent) 0%, var(--accent-2) 100%);
  border-radius: 3px;
  margin-top: 14px;
}

.mamapref-section h3 {
  margin: 20px 0 10px;
  font-size: 18px;
  color: #1f2937;
  font-weight: 700;
}

.mamapref-section p {
  margin: 0 0 16px;
  color: #475569;
  font-size: 15px;
  line-height: 1.8;
}

.mamapref-section p:last-child {
  margin-bottom: 0;
}

/* ========================================
   人気デートスポット
   ======================================== */


.mamapref-spots {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 22px;
  margin: 28px 0 0;
}

.mamapref-spot-item {
  position: relative;
  display: flex;
  flex-direction: column;
  background: var(--card);
  border-radius: 24px;
  border: 1px solid rgba(148, 163, 184, 0.18);
  box-shadow: 0 28px 68px rgba(15, 23, 42, 0.16);
  overflow: hidden;
  transition: transform 0.16s ease, box-shadow 0.16s ease;
  padding: 24px;
  gap: 12px;
}

.mamapref-spot-item:hover {
  transform: translateY(-4px);
  box-shadow: 0 32px 80px rgba(15, 23, 42, 0.2);
}

.mamapref-spot-item h4 {
  margin: 0;
  font-size: 18px;
  color: var(--accent);
  font-weight: 700;
  line-height: 1.5;
  letter-spacing: -0.01em;
}

.mamapref-spot-item p {
  margin: 0;
  font-size: 14px;
  color: #475569;
  line-height: 1.7;
}

.mamapref-spot-item p strong {
  color: #0f172a;
  font-weight: 700;
  display: block;
  margin-bottom: 6px;
  font-size: 13px;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: #64748b;
}

/* ========================================
   地域特有のNG行動
   ======================================== */

.mamapref-ng-list {
  list-style: none;
  margin: 28px 0 0;
  padding: 0;
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
  gap: 20px;
}

.mamapref-ng-list li {
  position: relative;
  background: linear-gradient(135deg, #fff5f5 0%, #ffe0e0 100%);
  border-left: 4px solid var(--danger);
  padding: 24px;
  border-radius: 14px;
  border: 1px solid rgba(239, 71, 111, 0.2);
  transition: all 0.3s ease;
}

.mamapref-ng-list li:hover {
  transform: translateY(-4px);
  box-shadow: 0 8px 24px rgba(239, 71, 111, 0.15);
}

.mamapref-ng-list li strong {
  display: block;
  color: #a11a3d;
  font-weight: 700;
  margin-bottom: 10px;
  font-size: 16px;
}

.mamapref-ng-list li p {
  margin: 0;
  color: #7c2d12;
  font-size: 14px;
  line-height: 1.7;
}

/* ========================================
   成功者の声
   ======================================== */

.mamapref-stories {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(340px, 1fr));
  gap: 28px;
  margin: 28px 0 0;
}

.mamapref-story-item {
  position: relative;
  display: flex;
  flex-direction: column;
  background: var(--card);
  border-radius: 24px;
  border: 1px solid rgba(148, 163, 184, 0.18);
  box-shadow: 0 28px 68px rgba(15, 23, 42, 0.16);
  overflow: hidden;
  transition: transform 0.16s ease, box-shadow 0.16s ease;
  padding: 28px;
  gap: 14px;
}

.mamapref-story-item::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 4px;
  background: linear-gradient(90deg, var(--accent) 0%, var(--accent-2) 100%);
}

.mamapref-story-item::after {
  content: '"';
  position: absolute;
  top: 12px;
  right: 20px;
  font-size: 64px;
  color: rgba(249, 115, 22, 0.1);
  font-weight: 900;
  line-height: 1;
}

.mamapref-story-item:hover {
  transform: translateY(-4px);
  box-shadow: 0 32px 80px rgba(15, 23, 42, 0.2);
}

.mamapref-story-title {
  margin: 0;
  font-size: 17px;
  color: #0f172a;
  font-weight: 700;
  line-height: 1.5;
  letter-spacing: -0.01em;
}

.mamapref-story-content {
  margin: 0;
  font-size: 14px;
  color: #475569;
  line-height: 1.8;
  font-style: italic;
}

.mamapref-story-lesson {
  margin: 0;
  padding: 14px 16px;
  background: linear-gradient(135deg, #eff6ff 0%, #dbeafe 100%);
  border-radius: 10px;
  border-left: 3px solid var(--accent-2);
  font-size: 13px;
  color: #0c4a6e;
  font-style: normal;
  font-weight: 600;
  line-height: 1.6;
}

/* ========================================
   レスポンシブ調整
   ======================================== */

@media (max-width: 1024px) {
  .mamapref-section {
    margin: 40px 0;
  }

  .mamapref-section h2 {
    font-size: 28px;
    margin-bottom: 28px;
  }

  .mamapref-spots {
    grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
    gap: 20px;
  }

  .mamapref-ng-list {
    grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
    gap: 18px;
  }

  .mamapref-stories {
    grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
    gap: 24px;
  }
}

@media (max-width: 768px) {
  .mamapref-section {
    margin: 32px 0;
  }

  .mamapref-section h2 {
    font-size: 24px;
    margin-bottom: 24px;
  }

  .mamapref-section h2::after {
    width: 60px;
    height: 4px;
    margin-top: 10px;
  }

  .mamapref-spots {
    grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
    gap: 16px;
  }

  .mamapref-spot-item {
    padding: 20px;
  }

  .mamapref-spot-item h4 {
    font-size: 16px;
  }

  .mamapref-ng-list {
    grid-template-columns: 1fr;
    gap: 14px;
  }

  .mamapref-ng-list li {
    padding: 20px;
  }

  .mamapref-stories {
    grid-template-columns: 1fr;
    gap: 20px;
  }

  .mamapref-story-item {
    padding: 24px;
  }

  .mamapref-story-title {
    font-size: 16px;
  }

  .mamapref-story-content {
    font-size: 13px;
  }
}

@media (max-width: 480px) {
  .mamapref-section {
    margin: 24px 0;
  }

  .mamapref-section h2 {
    font-size: 20px;
    margin-bottom: 20px;
  }

  .mamapref-section h2::after {
    width: 50px;
    height: 3px;
    margin-top: 8px;
  }

  .mamapref-section h3 {
    font-size: 17px;
  }

  .mamapref-section p {
    font-size: 14px;
  }

  .mamapref-spots {
    grid-template-columns: 1fr;
    gap: 12px;
  }

  .mamapref-spot-item {
    padding: 16px;
  }

  .mamapref-spot-item h4 {
    font-size: 15px;
  }

  .mamapref-spot-item p {
    font-size: 13px;
  }

  .mamapref-ng-list li {
    padding: 16px;
  }

  .mamapref-ng-list li strong {
    font-size: 15px;
  }

  .mamapref-ng-list li p {
    font-size: 13px;
  }

  .mamapref-story-item {
    padding: 18px;
  }

  .mamapref-story-item::after {
    font-size: 48px;
    right: 12px;
  }

  .mamapref-story-title {
    font-size: 15px;
  }

  .mamapref-story-content {
    font-size: 12px;
  }

  .mamapref-story-lesson {
    font-size: 12px;
    padding: 12px 14px;
  }
}


/* ========================================
   新しい地域ナビゲーション（prefecture-navigation）
   見やすく、押しやすく、遷移しやすい設計
   ======================================== */

.prefecture-navigation {
  max-width: 1100px;
  margin: 48px auto 0;
  padding: 32px 36px;
  border-radius: 28px;
  background: linear-gradient(145deg, #ffffff 0%, #f6f7ff 50%, #eef4ff 100%);
  border: 1px solid rgba(148, 163, 184, 0.22);
  box-shadow: 0 28px 64px -36px rgba(30, 41, 59, 0.48);
}

.prefecture-navigation__container {
  width: 100%;
}

.prefecture-navigation__header {
  margin-bottom: 32px;
  text-align: center;
}

.prefecture-navigation__title {
  margin: 0 0 12px;
  font-size: clamp(24px, 3vw, 32px);
  font-weight: 800;
  color: #1e293b;
  letter-spacing: 0.03em;
}

.prefecture-navigation__subtitle {
  margin: 0;
  font-size: 16px;
  color: #64748b;
  font-weight: 500;
}

/* クイックセレクト（モバイル対応） */
.prefecture-navigation__quick-select {
  display: none;
  margin-bottom: 24px;
}

.prefecture-navigation__select-label {
  position: absolute;
  clip: rect(1px, 1px, 1px, 1px);
  padding: 0;
  border: 0;
  height: 1px;
  width: 1px;
  overflow: hidden;
  white-space: nowrap;
}

.prefecture-navigation__select-control {
  width: 100%;
  padding: 12px 18px;
  border-radius: 12px;
  border: 1px solid rgba(148, 163, 184, 0.25);
  background: #ffffff;
  font-size: 14px;
  font-weight: 600;
  color: #1f2937;
  box-shadow: 0 18px 38px -30px rgba(30, 41, 59, 0.45);
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  background-image: url('data:image/svg+xml,%3Csvg width="12" height="8" viewBox="0 0 12 8" xmlns="http://www.w3.org/2000/svg"%3E%3Cpath d="M1 1.5L6 6.5L11 1.5" stroke="%23343F5E" stroke-width="1.6" stroke-linecap="round" stroke-linejoin="round"/%3E%3C/svg%3E');
  background-repeat: no-repeat;
  background-position: right 16px center;
  background-size: 12px auto;
  cursor: pointer;
}

.prefecture-navigation__select-control:focus {
  outline: none;
  box-shadow: 0 0 0 3px rgba(56, 189, 248, 0.35);
}

/* 地域ブロック表示 */
.prefecture-navigation__blocks {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 24px;
}

.prefecture-block {
  background: #ffffff;
  border-radius: 16px;
  border: 1px solid rgba(148, 163, 184, 0.15);
  padding: 24px;
  box-shadow: 0 12px 32px -12px rgba(30, 41, 59, 0.2);
  transition: transform 0.16s ease, box-shadow 0.16s ease;
}

@media (hover: hover) {
  .prefecture-block:hover {
    transform: translateY(-4px);
    box-shadow: 0 18px 48px -16px rgba(30, 41, 59, 0.3);
  }
}

.prefecture-block__title {
  margin: 0 0 18px;
  font-size: 18px;
  font-weight: 700;
  color: #1e293b;
  border-bottom: 2px solid rgba(249, 115, 22, 0.3);
  padding-bottom: 12px;
}

.prefecture-block__list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 10px;
}

.prefecture-block__item {
  margin: 0;
}

.prefecture-block__link {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 11px 14px;
  border-radius: 10px;
  background: #f8f9ff;
  border: 1px solid rgba(148, 163, 184, 0.15);
  font-size: 13px;
  font-weight: 600;
  color: #1f2937;
  text-decoration: none;
  text-align: center;
  box-shadow: 0 6px 16px -8px rgba(30, 41, 59, 0.15);
  transition: transform 0.12s ease, box-shadow 0.12s ease, background 0.12s ease, color 0.12s ease;
}

.prefecture-block__link:focus-visible {
  outline: 3px solid rgba(56, 189, 248, 0.45);
  outline-offset: 2px;
}

@media (hover: hover) {
  .prefecture-block__link:hover {
    transform: translateY(-2px);
    box-shadow: 0 12px 24px -8px rgba(30, 41, 59, 0.25);
    background: linear-gradient(120deg, rgba(249, 115, 22, 0.12), rgba(56, 189, 248, 0.12));
    color: var(--accent);
  }
}

/* セカンダリナビゲーション（ページ下部） */
.prefecture-navigation-secondary {
  max-width: 1100px;
  margin: 64px auto 0;
  padding: 32px 36px;
  border-radius: 28px;
  background: linear-gradient(145deg, #f6f7ff 0%, #eef4ff 50%, #ffffff 100%);
  border: 1px solid rgba(148, 163, 184, 0.15);
  box-shadow: 0 28px 64px -36px rgba(30, 41, 59, 0.32);
}

.prefecture-navigation-secondary__container {
  width: 100%;
}

.prefecture-navigation-secondary__title {
  margin: 0 0 28px;
  font-size: clamp(20px, 2.4vw, 26px);
  font-weight: 700;
  color: #1e293b;
  letter-spacing: 0.03em;
  text-align: center;
  position: relative;
  padding-bottom: 16px;
}

.prefecture-navigation-secondary__title::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 60px;
  height: 3px;
  border-radius: 999px;
  background: linear-gradient(90deg, #f97316, #38bdf8);
}

.prefecture-navigation-secondary__blocks {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: 20px;
}

.prefecture-block-secondary {
  background: #ffffff;
  border-radius: 14px;
  border: 1px solid rgba(148, 163, 184, 0.12);
  padding: 20px;
  box-shadow: 0 8px 24px -10px rgba(30, 41, 59, 0.15);
  transition: transform 0.12s ease, box-shadow 0.12s ease;
}

@media (hover: hover) {
  .prefecture-block-secondary:hover {
    transform: translateY(-2px);
    box-shadow: 0 12px 32px -12px rgba(30, 41, 59, 0.25);
  }
}

.prefecture-block-secondary__title {
  margin: 0 0 14px;
  font-size: 16px;
  font-weight: 700;
  color: #1e293b;
  border-bottom: 1px solid rgba(249, 115, 22, 0.2);
  padding-bottom: 10px;
}

.prefecture-block-secondary__list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 8px;
}

.prefecture-block-secondary__item {
  margin: 0;
}

.prefecture-block-secondary__link {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 9px 12px;
  border-radius: 8px;
  background: #f1f5f9;
  border: 1px solid rgba(148, 163, 184, 0.1);
  font-size: 12px;
  font-weight: 600;
  color: #1f2937;
  text-decoration: none;
  text-align: center;
  box-shadow: 0 4px 12px -6px rgba(30, 41, 59, 0.1);
  transition: transform 0.12s ease, box-shadow 0.12s ease, background 0.12s ease, color 0.12s ease;
}

.prefecture-block-secondary__link:focus-visible {
  outline: 2px solid rgba(56, 189, 248, 0.45);
  outline-offset: 1px;
}

@media (hover: hover) {
  .prefecture-block-secondary__link:hover {
    transform: translateY(-1px);
    box-shadow: 0 6px 16px -6px rgba(30, 41, 59, 0.2);
    background: rgba(249, 115, 22, 0.1);
    color: var(--accent);
  }
}

/* モバイル対応 */
@media (max-width: 768px) {
  .prefecture-navigation {
    margin: 32px 16px 0;
    padding: 24px 20px;
    border-radius: 20px;
  }

  .prefecture-navigation__header {
    margin-bottom: 24px;
  }

  .prefecture-navigation__title {
    font-size: clamp(20px, 2.5vw, 26px);
  }

  .prefecture-navigation__quick-select {
    display: block;
  }

  .prefecture-navigation__blocks {
    grid-template-columns: 1fr;
    gap: 16px;
  }

  .prefecture-block {
    padding: 20px;
  }

  .prefecture-block__list {
    grid-template-columns: repeat(3, 1fr);
    gap: 8px;
  }

  .prefecture-block__link {
    padding: 10px 12px;
    font-size: 12px;
  }

  .prefecture-navigation-secondary {
    margin: 48px 16px 0;
    padding: 24px 20px;
    border-radius: 20px;
  }

  .prefecture-navigation-secondary__blocks {
    grid-template-columns: 1fr;
    gap: 16px;
  }

  .prefecture-block-secondary {
    padding: 16px;
  }

  .prefecture-block-secondary__list {
    grid-template-columns: repeat(3, 1fr);
    gap: 6px;
  }

  .prefecture-block-secondary__link {
    padding: 8px 10px;
    font-size: 11px;
  }
}

@media (max-width: 480px) {
  .prefecture-navigation {
    margin: 24px 12px 0;
    padding: 20px 16px;
  }

  .prefecture-navigation__title {
    font-size: 20px;
  }

  .prefecture-navigation__subtitle {
    font-size: 14px;
  }

  .prefecture-block__list {
    grid-template-columns: repeat(2, 1fr);
  }

  .prefecture-block-secondary__list {
    grid-template-columns: repeat(2, 1fr);
  }
}
