/*
Theme Name: うちの子SOSナビ
Theme URI: https://nizihashi-relief.com/
Author: うちの子SOSナビ編集部
Author URI: https://nizihashi-relief.com/about/
Description: 犬・猫と暮らす人のためのオウンドメディア「うちの子SOSナビ」用テーマ。FLOCSS + BEM 命名規則準拠。詳細は docs/CLAUDE.md および docs/wp-migration.md 参照。
Version: 0.1.0
Requires at least: 6.0
Requires PHP: 8.0
License: All Rights Reserved
Text Domain: uchinoko-sos-navi
*/

/* ===========================================================
   このファイルについて
   - 上部の WordPress テーマ識別ヘッダーは必須（編集する場合は注意）。
   - 以下のスタイルは _prototype/styles.css の内容を移植したものです。
   - フェーズ2-A の段階で SCSS（FLOCSS + BEM）に分解することを推奨します。
   =========================================================== */

/* === Tokens === */
:root{
  --bg: #FFF9F2;
  --bg-soft: #FFF3E8;
  --card: #FFFFFF;
  --ink: #3E2D24;
  --ink-2: #5e4a3e;
  --muted: #8E7A6F;
  --rule: #EFE3D5;

  --coral: #F08A70;
  --coral-2: #F4A89A;
  --coral-soft: #FCE2D9;
  --sage: #7FB8AB;
  --sage-soft: #DFEEE8;
  --yellow: #F5D88B;
  --yellow-soft: #FCEFC8;
  --cream: #FBE4C7;

  --shadow-sm: 0 2px 6px rgba(94, 68, 51, .06);
  --shadow-md: 0 8px 24px rgba(94, 68, 51, .08);
  --radius: 14px;
  --radius-lg: 20px;

  --font-jp: "Zen Maru Gothic", "Noto Sans JP", system-ui, sans-serif;
  --font-jp-body: "Noto Sans JP", "Zen Maru Gothic", system-ui, sans-serif;
  --font-num: "Plus Jakarta Sans", "Noto Sans JP", sans-serif;
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
html{overflow-x: clip}
body{
  background: var(--bg);
  color: var(--ink);
  font-family: var(--font-jp-body);
  font-size: 14px;
  line-height: 1.7;
  -webkit-font-smoothing: antialiased;
  overflow-x: clip;
}
img,svg{max-width:100%}
a{color:inherit;text-decoration:none}
ul,ol{margin:0;padding:0;list-style:none}
img{display:block;max-width:100%}
button{font: inherit; cursor: pointer; border:0; background:none; color:inherit}
input{font:inherit}

.container{max-width:1140px;margin:0 auto;padding: 0 28px}

/* ============ Header ============ */
.site-header{
  background: var(--bg);
  position: sticky; top:0; z-index: 30;
}
.header-inner{
  display:flex; align-items:center; gap: 28px;
  padding: 18px 28px;
}
.brand{display:flex;align-items:center;gap:10px}
.brand-mark{width:46px;height:46px;object-fit:contain}
.brand-words{display:flex;flex-direction:column;line-height:1.15}
.brand-name{font-family:var(--font-jp);font-weight:700;font-size:16px;letter-spacing:.02em}
.brand-tag{font-size:10.5px;color:var(--muted)}

.nav{display:flex; gap:30px; margin-left: 24px}
.nav-link{
  position:relative;
  font-family: var(--font-jp);
  font-weight:500;
  font-size: 14px;
  color: var(--ink);
  display:inline-flex;align-items:center;gap:5px;
  padding: 6px 0;
}
.nav-link.is-active{color: var(--coral)}
.nav-link.is-active::after{
  content:""; position:absolute; left:50%; right:auto; bottom: -2px;
  width: 28px; height: 2px; border-radius: 2px;
  background: var(--coral);
  transform: translateX(-50%);
}
.nav-link:hover{color: var(--coral)}

/* === ドロップダウン（カテゴリーサブメニュー） === */
.nav-item{ position: relative; display: inline-flex; align-items: center }
.nav-item--has-submenu .nav-link{ cursor: pointer }
.nav-item--has-submenu .nav-link svg{
  transition: transform .2s ease;
}
.nav-item--has-submenu:hover .nav-link svg,
.nav-item--has-submenu:focus-within .nav-link svg{
  transform: rotate(180deg);
}
.nav-submenu{
  position: absolute;
  top: 100%;
  left: 50%;
  transform: translateX(-50%) translateY(-4px);
  min-width: 240px;
  margin-top: 14px;       /* 視覚上のギャップ */
  padding: 8px;
  background: #fff;
  border: 1px solid var(--rule);
  border-radius: var(--radius);
  box-shadow: 0 12px 32px rgba(94, 68, 51, .14), 0 2px 8px rgba(94, 68, 51, .06);
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transition: opacity .18s ease, transform .18s ease, visibility .18s;
  z-index: 50;
}
/* hover/focus 時に隙間でドロップダウンが消えないよう、透明ブリッジ */
.nav-submenu::before{
  content: "";
  position: absolute;
  left: 0; right: 0;
  top: -14px; height: 14px;
}
.nav-item--has-submenu:hover .nav-submenu,
.nav-item--has-submenu:focus-within .nav-submenu{
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
  transform: translateX(-50%) translateY(0);
}
.nav-submenu__item{
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 9px 12px;
  border-radius: 10px;
  font-family: var(--font-jp);
  font-size: 13px;
  font-weight: 500;
  color: var(--ink);
  text-decoration: none;
  transition: background .15s ease, color .15s ease;
}
.nav-submenu__item:hover,
.nav-submenu__item:focus-visible{
  background: var(--coral-soft);
  color: var(--coral);
}
.nav-submenu__item.is-active{
  background: var(--coral-soft);
  color: var(--coral);
}
.nav-submenu__item--all{
  font-weight: 700;
  border-bottom: 1px dashed var(--rule);
  border-radius: 10px 10px 0 0;
  margin-bottom: 4px;
  padding-bottom: 12px;
}
.nav-submenu__item--all:hover{
  background: var(--bg-soft);
  color: var(--ink);
}
.nav-submenu__dot{
  flex: 0 0 auto;
  width: 8px; height: 8px; border-radius: 50%;
  background: var(--coral-2);
}
.nav-submenu__item.cat-training .nav-submenu__dot{ background: #7FB8AB }
.nav-submenu__item.cat-cat-life .nav-submenu__dot{ background: #C49BD9 }
.nav-submenu__item.cat-food .nav-submenu__dot{ background: #F08A70 }
.nav-submenu__item.cat-health .nav-submenu__dot{ background: #6FB1E0 }
.nav-submenu__item.cat-trip .nav-submenu__dot{ background: #F5C26B }
.nav-submenu__item.cat-goods .nav-submenu__dot{ background: #B7CF7A }
.nav-submenu__label{ flex: 1; min-width: 0 }
.nav-submenu__count{
  font-family: var(--font-num);
  font-size: 11px;
  color: var(--muted);
  background: var(--bg-soft);
  padding: 2px 8px;
  border-radius: 999px;
  flex: 0 0 auto;
}
.nav-submenu__caret{
  color: var(--coral);
  font-weight: 700;
}

.header-actions{margin-left:auto;display:flex;align-items:center;gap:12px}

/* ヘッダー右上のメインCTA：お問い合わせボタン */
.header-cta{
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: var(--coral);
  color: #fff;
  border-radius: 999px;
  padding: 10px 20px;
  font-family: var(--font-jp);
  font-weight: 700;
  font-size: 13.5px;
  letter-spacing: .02em;
  text-decoration: none;
  box-shadow: 0 6px 16px rgba(240, 138, 112, .32);
  transition: transform .18s ease, box-shadow .18s ease, background .18s ease;
}
.header-cta:hover,
.header-cta:focus-visible{
  background: #e87b62;
  transform: translateY(-1px);
  box-shadow: 0 8px 20px rgba(240, 138, 112, .42);
  color: #fff;
}
.header-cta.is-active{
  background: #e87b62;
}
.header-cta__icon{
  display: block;
  flex: 0 0 auto;
  transform: translateY(-0.5px);
}
.header-cta__label{ display: inline }

/* ============ Buttons ============ */
.btn{
  display:inline-flex; align-items:center; gap:8px;
  border-radius: 999px;
  padding: 10px 22px;
  font-family: var(--font-jp);
  font-weight:700;
  font-size: 13px;
  transition: transform .15s ease, background .2s ease;
}
.btn-primary{
  background: var(--coral);
  color:#fff;
  box-shadow: 0 6px 14px rgba(240,138,112,.3);
}
.btn-primary:hover{background:#e87b62; transform: translateY(-1px)}
.btn-lg{padding: 13px 28px; font-size: 14px}

.ghost-btn{
  display:inline-flex; align-items:center; gap:6px;
  background:#fff;
  border:1px solid var(--rule);
  border-radius: 999px;
  padding: 8px 18px;
  font-family:var(--font-jp);
  font-weight:500;
  font-size: 12.5px;
  color: var(--ink-2);
}
.ghost-btn:hover{border-color: var(--coral); color: var(--coral)}
.ghost-btn .caret{font-size: 16px; line-height: 1; color: var(--coral)}
.ghost-btn-pill{padding: 10px 26px}

/* ============ Hero ============ */
.hero{position:relative; padding: 30px 0 70px}
.hero-inner{
  position:relative;
  display:grid;
  grid-template-columns: 1fr 1fr;
  align-items:center;
  gap: 40px;
}
.hero-copy{position:relative; z-index:2; padding-left: 28px}
.hero-title{
  font-family: var(--font-jp);
  font-weight: 900;
  font-size: 54px;
  line-height: 1.25;
  letter-spacing: .01em;
  margin: 0 0 24px;
}
.hero-title .line{display:block}
.t-coral{color: var(--coral)}
.t-dark{color: var(--ink)}
.t-sage{color: var(--sage); margin-right: 8px}
.t-yellow{color: #E8B850}
.hero-lead{
  font-size: 14.5px;
  color: var(--ink-2);
  margin: 0 0 30px;
  line-height: 1.9;
}

/* hero art */
.hero-art{
  position:relative;
  width: 100%;
  aspect-ratio: 560/460;
}

/* スライドショー（前面） */
.hero-slideshow{
  position: absolute;
  inset: 0;
  z-index: 2;
}
.hero-slide{
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: center;
  filter: drop-shadow(0 10px 20px rgba(94,68,51,.08));
  border-radius: 58% 42% 48% 52% / 52% 60% 40% 48%;
  opacity: 0;
  transition: opacity 1s ease-in-out;
  will-change: opacity;
}
.hero-slide.is-active{opacity: 1}
@media (prefers-reduced-motion: reduce){
  .hero-slide{transition: none}
}

/* 装飾は背面（写真の下に置く） */
.float-blob,
.float-spark,
.float-paw{z-index: 1}

.float-blob{position:absolute;border-radius:50%}
.fb-yellow{
  width: 70px;height:70px;background:var(--yellow);
  top: -10px; right: 30px; opacity:.85;
}
.fb-sage{
  width: 95px;height:95px;background: #C4DDD5;
  bottom: 0; right: -12px;
  border-radius: 60% 40% 55% 45% / 50% 50% 50% 50%;
}
.fb-cream{
  width: 38px;height:38px; background: var(--coral-2);
  bottom: 30px; left: -16px;
}
.float-spark{position:absolute; width:60px; top: 12%; right: 8%; opacity:.8}
.float-paw{position:absolute; top: 38%; right: 6%; opacity:.85}
.float-paw-2{top: auto; bottom: 14%; right: 12%; opacity:.7}

/* hero decorations (background page level) */
.dec{position:absolute; pointer-events:none}
.dec-blob-1{width: 110px; left: -10px; top: 70px; opacity:.55; transform: rotate(-10deg)}
.dec-puff-1{width: 130px; left: -40px; top: -20px; opacity:.55}
.dec-spark-1{width: 80px; right: 20px; top: -10px; opacity:.7}
.dec-dots-1{width: 60px; left: -10px; bottom: 40px; opacity:.7}
.dec-dots-2{width: 50px; right: 38%; bottom: -10px; opacity:.6}
.dec-paw-1{position:absolute; right: 28%; top: 30%; opacity:.55}

/* ============ Main grid ============ */
.main-section{padding: 30px 0 70px; position:relative}
.main-grid{
  display:grid;
  grid-template-columns: 1fr 290px;
  gap: 30px;
  align-items:flex-start;
}

/* section head */
.section-head{
  display:flex; justify-content:space-between; align-items:center;
  margin-bottom: 18px;
}
.section-title{
  margin:0;
  font-family: var(--font-jp);
  font-weight: 900;
  font-size: 22px;
  display:inline-flex;align-items:center;gap:8px;
}

/* card */
.card{
  display:block;
  background: var(--card);
  border-radius: var(--radius);
  overflow:hidden;
  box-shadow: var(--shadow-sm);
  transition: transform .2s ease, box-shadow .2s ease;
}
.card:hover{transform: translateY(-2px); box-shadow: var(--shadow-md)}
.card-img{overflow:hidden}
.card-img img{width:100%;height:100%;object-fit:cover; transition: transform .4s ease}
.card:hover .card-img img{transform: scale(1.04)}
.card-body{padding: 16px 18px 14px}

/* featured */
.card-featured{
  display:grid;
  grid-template-columns: 320px 1fr;
}
.card-featured .card-img{height: 100%; min-height: 220px}
.card-featured .card-body{padding: 22px 24px}
.card-title-lg{
  font-family: var(--font-jp);
  font-weight: 700;
  font-size: 19px;
  line-height: 1.55;
  margin: 12px 0 10px;
  letter-spacing: .005em;
}
.card-excerpt{
  font-size: 12.5px; color: var(--muted);
  margin: 0 0 18px;
  line-height: 1.85;
}

/* small cards */
.card-row{
  display:grid; grid-template-columns: repeat(3, 1fr);
  gap: 16px;
  margin-top: 16px;
}
.card-sm .card-img{height: 138px}
.card-title-sm{
  font-family: var(--font-jp);
  font-weight: 700;
  font-size: 13px;
  line-height: 1.6;
  margin: 8px 0 12px;
}

/* category pills */
.cat-pill{
  display:inline-flex;align-items:center;
  font-family: var(--font-jp);
  font-weight:700;
  font-size: 11px;
  padding: 4px 12px;
  border-radius: 999px;
  background: var(--coral-soft);
  color: #c2654d;
}
.cat-train{background:#FCE2D9;color:#c2654d}
.cat-life{background:#EAE0F1;color:#7d5d96}
.cat-life-cat{background:#EAE0F1;color:#7d5d96}
.cat-trip{background:#E2EFD9;color:#5e8c46}
.cat-care{background:#DAEDF1;color:#3f7e8b}
.cat-food{background:#FBE9CC;color:#9b6f2c}

/* meta */
.card-meta{
  display:flex; align-items:center; gap: 14px;
  color: var(--muted);
  font-size: 11.5px;
  font-family: var(--font-num);
}
.card-meta .meta{display:inline-flex;align-items:center;gap:5px}
.card-meta.sm{gap:10px;font-size:11px}
.card-meta.sm .meta{position:relative}
.meta-views::before{content:"👁"; display:none}
.meta-views{
  display:inline-flex; align-items:center; gap:4px; font-family: var(--font-num);
}
.meta-views::before{
  content:""; display:inline-block; width:11px; height:11px;
  background: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none'><path d='M2 12s3.5-7 10-7 10 7 10 7-3.5 7-10 7S2 12 2 12z' stroke='%238E7A6F' stroke-width='1.6'/><circle cx='12' cy='12' r='3' stroke='%238E7A6F' stroke-width='1.6'/></svg>") center/contain no-repeat;
}
.meta-bookmark{margin-left:auto; display:inline-flex}

.more-row{display:flex; justify-content:center; margin-top: 28px}

/* ============ Sidebar ============ */
.sidebar{display:flex; flex-direction:column; gap: 18px}

.search-box{
  display:flex; align-items:center;
  background:#fff;
  border-radius: 999px;
  border:1px solid var(--rule);
  overflow:hidden;
  box-shadow: var(--shadow-sm);
}
.search-box input{
  flex:1; border:0; outline:none;
  padding: 11px 16px;
  font-size: 12.5px;
  background: transparent;
  color: var(--ink);
}
.search-box input::placeholder{color: var(--muted)}
.search-box button{
  background: var(--coral);
  width: 40px; height: 40px;
  display:grid;place-items:center;
  border-radius: 50%;
  margin: 2px;
}

.side-card{
  background:#fff;
  border-radius: var(--radius);
  padding: 20px 18px;
  box-shadow: var(--shadow-sm);
}
.side-title{
  margin:0 0 14px;
  font-family: var(--font-jp);
  font-weight: 700;
  font-size: 14px;
  display:inline-flex;align-items:center;gap:7px;
}

.rank-row{
  display:flex; align-items:flex-start; gap:10px;
  padding: 10px 0;
  border-top: 1px solid var(--rule);
}
.rank-row:first-of-type{border-top:0;padding-top:6px}
.rank{
  flex-shrink:0;
  width: 22px; height: 22px;
  border-radius: 50%;
  background: var(--coral);
  color: #fff;
  font-family: var(--font-num);
  font-weight: 700;
  font-size: 12px;
  display:grid; place-items:center;
}
.rank-1{background: #E8B850}
.rank-2{background: #B6B6B6}
.rank-3{background: #C49060}
.rank-row img{
  width: 50px; height: 50px;
  border-radius: 8px;
  object-fit: cover; flex-shrink:0;
}
.rank-body{flex:1;min-width:0}
.rank-title{
  font-family: var(--font-jp); font-weight:500;
  font-size: 12px; line-height: 1.5;
  margin: 0 0 4px;
}
.rank-views{font-size: 11px; color: var(--muted); font-family: var(--font-num)}

.cat-list li{
  display:flex; justify-content:space-between; align-items:center;
  padding: 9px 0;
  border-top: 1px dashed var(--rule);
  font-size: 12.5px;
}
.cat-list li:first-child{border-top:0}
.cat-list a{color: var(--ink-2)}
.cat-list a:hover{color: var(--coral)}
.cat-list span{
  color: var(--muted); font-size: 11px;
  font-family: var(--font-num);
}

.side-btn{
  display:block; text-align:center;
  margin-top: 14px;
  padding: 9px 14px;
  border: 1px solid var(--rule);
  border-radius: 999px;
  font-size: 11.5px;
  color: var(--ink-2);
  font-family: var(--font-jp);
  font-weight: 500;
}
.side-btn:hover{border-color: var(--coral); color: var(--coral)}

.rank-mini li{
  display:flex; gap:10px; align-items:flex-start;
  padding: 9px 0;
  border-top: 1px dashed var(--rule);
}
.rank-mini li:first-child{border-top:0}
.rank-mini .num{
  font-family: var(--font-num);
  font-weight: 700;
  font-size: 16px;
  color: var(--coral);
  min-width: 16px;
  line-height: 1.3;
}
.rank-mini p{margin:0; font-size: 12px; line-height: 1.55; font-family: var(--font-jp)}
.rank-mini .views{
  display:block; margin-top: 4px;
  font-size: 11px; color: var(--muted);
  font-family: var(--font-num);
}

/* author card */
.author-card{background: linear-gradient(180deg, #FFF6EE 0%, #fff 100%)}
.author{display:flex; gap:10px; align-items:flex-start; padding: 4px 0 8px}
.author img{
  width: 46px; height: 46px; border-radius: 50%;
  object-fit: cover; flex-shrink:0;
}
.author p{margin:0; font-size: 11.5px; line-height: 1.7; color: var(--ink-2)}

/* ============ Quad section ============ */
.quad-section{padding: 30px 0 60px}
.quad-grid{
  display:grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 16px;
}
.quad{
  position:relative;
  border-radius: var(--radius);
  padding: 22px 20px 24px;
  overflow: hidden;
  min-height: 220px;
  display:flex; flex-direction:column;
}
.quad-1{background: #FCE2D9}
.quad-2{background: #FCEFC8}
.quad-3{background: var(--sage-soft)}
.quad-4{background: #FAD9CC}
.quad-title{
  font-family: var(--font-jp);
  font-weight: 700;
  font-size: 18px;
  margin: 0 0 12px;
}
.quad p{font-size: 12px; color: var(--ink-2); line-height: 1.85; margin:0 0 16px}
.quad-list{display:flex; flex-direction:column; gap:6px; margin: 0 0 16px}
.quad-list li{
  font-size: 11.5px; color: var(--ink-2);
  padding-left: 18px; position:relative; line-height: 1.7;
}
.quad-list li::before{
  content:""; position:absolute; left: 0; top:7px;
  width: 10px; height: 10px;
  background: #fff;
  border-radius: 50%;
}
.q-list li::before{
  content:"Q"; color: var(--coral); font-weight: 700;
  background: transparent; width: auto; height: auto;
  font-size: 11px; top: 1px; font-family: var(--font-num);
}
.quad-link{
  margin-top: auto;
  align-self:flex-start;
  display:inline-flex; align-items:center; gap:6px;
  background:#fff;
  padding: 8px 18px;
  border-radius: 999px;
  font-family: var(--font-jp);
  font-weight: 700;
  font-size: 11.5px;
  color: var(--ink);
  box-shadow: var(--shadow-sm);
}
.quad-link span{color: var(--coral); font-weight:700}
.quad-link:hover{color: var(--coral)}

/* 線画イラストの装飾。右下に小さく・低不透明度で配置し、文字や CTA に重ならないよう pointer-events も無効化 */
.quad-deco{
  position: absolute;
  right: 14px;
  bottom: 14px;
  width: 78px;
  height: auto;
  opacity: .55;
  pointer-events: none;
  user-select: none;
}

/* ============ Newsletter ============ */
.newsletter{padding: 0 0 50px}
.nl-inner{
  position:relative;
  display:flex; align-items:center; gap: 22px;
  background: #fff;
  border-radius: var(--radius-lg);
  padding: 22px 32px;
  border: 1px solid var(--rule);
}
.nl-icon{flex-shrink:0}
.nl-text{flex: 1}
.nl-title{
  font-family: var(--font-jp);
  font-weight: 700;
  font-size: 14.5px;
  margin: 0 0 4px;
}
.nl-sub{font-size: 11.5px; color: var(--muted); margin:0}
.nl-cta{
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 11px 22px;
  white-space: nowrap;
  flex-shrink: 0;
}
.nl-cta .caret{
  font-weight: 700;
  margin-left: 2px;
}
.nl-deco{
  position:absolute; right: 16px; bottom: -4px; width: 80px; opacity:.7;
}

/* ============ Footer ============ */
.site-footer{
  background: #fff;
  padding: 40px 0 24px;
  border-top: 1px solid var(--rule);
  position: relative;
}
.footer-grid{
  display:grid;
  grid-template-columns: 1.4fr 1fr 1fr 1fr;
  gap: 32px;
  position: relative;
}
.foot-brand{position:relative}
.foot-mini{font-size: 11px; color: var(--muted); margin: 12px 0 18px; line-height: 1.7}
.socials{display:flex; gap: 14px; color: var(--ink-2)}
.socials a{
  width: 28px; height: 28px;
  border-radius: 50%;
  display:grid; place-items:center;
}
.socials a:hover{color: var(--coral)}

.foot-h{
  font-family: var(--font-jp); font-weight: 700;
  font-size: 13px; margin: 0 0 14px;
}
.foot-col ul{display:flex;flex-direction:column;gap:10px}
.foot-col a{font-size: 11.5px; color: var(--ink-2)}
.foot-col a:hover{color: var(--coral)}

.foot-mascot{
  position:absolute;
  right: 0; top: -6px;
  width: 80px;
  opacity: .9;
}
.foot-bottom{
  margin-top: 28px;
  padding-top: 18px;
  border-top: 1px solid var(--rule);
  display:flex; justify-content:center;
  font-size: 11px; color: var(--muted);
  font-family: var(--font-num);
}
.to-top{
  position:absolute;
  right: 22px; bottom: 22px;
  width: 38px; height: 38px;
  border-radius: 50%;
  background:#fff;
  border: 1px solid var(--rule);
  display:grid; place-items:center;
  box-shadow: var(--shadow-sm);
}

/* === decorative paw scattered across page === */
.bg-paw{position:absolute; opacity:.5}

/* min-width:0 を効かせ、grid内のテキストや画像が縮められるように */
.hero-copy, .articles, .sidebar, .card-body, .rank-body,
.foot-col, .nl-text{min-width: 0}

/* ============================================================
   Responsive
   1140 (base) / 1080 / 920 / 720 / 480
   ============================================================ */

@media (max-width: 1080px){
  .hero-title{font-size:44px}
  .card-featured{grid-template-columns: 260px 1fr}
  .main-grid{grid-template-columns: 1fr 260px; gap: 24px}
}

@media (max-width: 920px){
  .nav{display:none}
  .header-inner{gap: 16px}
  .main-grid{grid-template-columns: 1fr; gap: 32px}
  .hero-inner{grid-template-columns: 1fr}
  .hero-copy{padding-left: 0; order: 2}
  .hero-art{order: 1; max-width: 480px; margin: 0 auto}
  .hero-title{font-size: 38px}
  .card-featured{grid-template-columns: 1fr}
  .card-featured .card-img{min-height: 0; aspect-ratio: 16/9}
  .quad-grid{grid-template-columns: repeat(2, 1fr)}
  .footer-grid{grid-template-columns: 1fr 1fr; gap: 28px}
  .foot-mascot{width: 64px}
  .nl-inner{flex-wrap: wrap; padding: 22px 24px}
  .nl-cta{flex: 1 1 100%; justify-content: center}
  .nl-deco{width: 64px; right: 12px}
}

@media (max-width: 720px){
  .container{padding: 0 18px}
  .header-inner{padding: 14px 18px; gap: 10px}
  .brand-mark{width: 38px; height: 38px}
  .brand-name{font-size: 14px}
  .brand-tag{font-size: 10px}
  .header-cta{padding: 8px 14px; font-size: 12.5px; gap: 6px}
  .header-cta__icon{width: 14px; height: 14px}

  .hero{padding: 20px 0 50px}
  .hero-title{font-size: 30px; margin-bottom: 18px}
  .hero-lead{font-size: 13.5px; margin-bottom: 22px}
  .hero-art{max-width: 380px}

  /* 装飾は狭幅では消す（情報の邪魔・はみ出し対策） */
  .dec-puff-1, .dec-blob-1, .dec-spark-1,
  .dec-dots-1, .dec-dots-2, .dec-paw-1{display: none}
  .float-spark{width: 44px}

  .section-title{font-size: 19px}
  .card-row{grid-template-columns: repeat(2, 1fr); gap: 12px}
  .card-sm .card-img{height: 120px}

  .quad-grid{grid-template-columns: 1fr}
  .quad{min-height: auto; padding: 20px 18px}
  .quad-deco{width: 64px; right: 12px; bottom: 12px}

  .footer-grid{grid-template-columns: 1fr 1fr; gap: 24px}
  .foot-mascot{display: none}
  .nl-deco{display: none}
  .nl-inner{padding: 20px 20px}
  .nl-title{font-size: 13.5px}

  .to-top{right: 16px; bottom: 16px}
}

@media (max-width: 480px){
  .container{padding: 0 14px}
  .header-inner{padding: 12px 14px; gap: 8px}
  .brand-tag{display: none}
  /* お問い合わせCTAはアイコンのみの円形に縮約 */
  .header-cta{
    padding: 0;
    width: 38px; height: 38px;
    border-radius: 50%;
    justify-content: center;
    gap: 0;
    box-shadow: 0 4px 10px rgba(240, 138, 112, .32);
  }
  .header-cta__label{ display: none }
  .header-cta__icon{ width: 16px; height: 16px; transform: none }

  .hero-title{font-size: 26px; line-height: 1.3}
  .hero-art{max-width: 320px}

  .card-row{grid-template-columns: 1fr; gap: 14px}
  .card-sm .card-img{height: 180px}

  .card-featured .card-body{padding: 18px 18px}
  .card-title-lg{font-size: 17px}

  .footer-grid{grid-template-columns: 1fr; gap: 20px}
  .foot-bottom{font-size: 10.5px}

  .nl-inner{padding: 18px 16px; gap: 12px}
  .nl-icon svg{width: 32px; height: 32px}
  .nl-form{flex-direction: column; align-items: stretch; gap: 8px; width: 100%}
  .nl-form input{width: 100%}
  .nl-form .btn{width: 100%; justify-content: center}

  .quad-photo{width: 96px; height: 96px}
}

/* ============================================================
   Article Detail (FLOCSS + BEM, new components only)
   - Layer: c- (component) / p- (project)
   - 既存トークン (var(--coral) 等) のみ使用、ハードコード値は最小限
   ============================================================ */

/* Reading progress bar -------------------------------------- */
.c-progress{
  position: fixed; top: 0; left: 0; right: 0;
  height: 3px; z-index: 50;
  background: rgba(255, 233, 220, .45);
  pointer-events: none;
}
.c-progress__bar{
  height: 100%; width: 0;
  background: linear-gradient(90deg, var(--coral), var(--yellow));
  transition: width .1s linear;
}

/* Breadcrumb ------------------------------------------------ */
.c-breadcrumb{
  padding: 14px 0 4px;
  font-size: 12px;
  color: var(--muted);
}
.c-breadcrumb__list{
  display: flex; flex-wrap: wrap; align-items: center;
  gap: 4px 6px;
  font-family: var(--font-jp);
}
.c-breadcrumb__list li{
  display: inline-flex; align-items: center;
}
.c-breadcrumb__list li + li::before{
  content: "›";
  margin: 0 8px 0 2px;
  color: var(--coral-2);
  font-weight: 700;
}
.c-breadcrumb__list a{
  color: var(--ink-2);
  transition: color .15s ease;
}
.c-breadcrumb__list a:hover{ color: var(--coral) }
.c-breadcrumb__list [aria-current="page"]{
  color: var(--ink);
  font-weight: 700;
  /* SP では長くなりがちなので末尾を省略 */
  max-width: 100%;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

/* Article layout -------------------------------------------- */
.p-article{ padding: 8px 0 60px; position: relative }
.p-article__layout{
  display: grid;
  grid-template-columns: 1fr 290px;
  gap: 40px;
  align-items: flex-start;
}
.p-article__main{ min-width: 0 }

/* Article header ------------------------------------------- */
.p-article__header{ margin-bottom: 28px }
.p-article__cats{
  display: flex; gap: 8px; flex-wrap: wrap;
  margin-bottom: 14px;
}
.p-article__title{
  font-family: var(--font-jp);
  font-weight: 900;
  font-size: 32px;
  line-height: 1.45;
  letter-spacing: .005em;
  margin: 0 0 18px;
  color: var(--ink);
}
.p-article__lead{
  font-size: 14.5px;
  line-height: 1.95;
  color: var(--ink-2);
  margin: 0 0 22px;
  padding-left: 14px;
  border-left: 3px solid var(--coral-soft);
}
.p-article__meta{
  display: flex; flex-wrap: wrap;
  gap: 6px 18px;
  font-size: 12px;
  color: var(--muted);
  font-family: var(--font-num);
  margin: 0 0 20px;
}
.p-article__meta-item{
  display: inline-flex; align-items: center; gap: 5px;
}

/* Bylines (author + supervisor compact) -------------------- */
.p-article__bylines{
  display: flex; flex-wrap: wrap;
  gap: 10px 14px;
  padding: 12px 14px;
  background: #fff;
  border: 1px solid var(--rule);
  border-radius: var(--radius);
  margin: 0 0 24px;
}
.c-byline{
  display: flex; align-items: center; gap: 10px;
  flex: 1 1 auto; min-width: 0;
}
.c-byline + .c-byline{
  padding-left: 14px;
  border-left: 1px dashed var(--rule);
}
.c-byline__avatar{
  width: 40px; height: 40px;
  border-radius: 50%;
  object-fit: cover;
  flex-shrink: 0;
}
.c-byline__body{ display: flex; flex-direction: column; min-width: 0 }
.c-byline__role{
  font-size: 10.5px; color: var(--muted);
  font-family: var(--font-jp);
  letter-spacing: .04em;
}
.c-byline__name{
  font-family: var(--font-jp);
  font-weight: 700;
  font-size: 13px;
  color: var(--ink);
  line-height: 1.4;
}
.c-byline--supervisor .c-byline__role{ color: var(--coral) }

/* Hero figure ---------------------------------------------- */
.p-article__hero{
  margin: 0 0 24px;
  border-radius: var(--radius-lg);
  overflow: hidden;
  box-shadow: var(--shadow-sm);
  background: #fff;
}
.p-article__hero img{
  width: 100%; height: auto; display: block;
  aspect-ratio: 16 / 9;
  object-fit: cover;
}
.p-article__hero figcaption{
  padding: 10px 16px 14px;
  font-size: 11.5px;
  color: var(--muted);
  text-align: center;
}

/* Share row ------------------------------------------------ */
.c-share{
  display: flex; flex-wrap: wrap; align-items: center;
  gap: 8px;
  padding: 12px 0 4px;
}
.c-share__label{
  font-size: 11.5px;
  color: var(--muted);
  font-family: var(--font-jp);
  margin-right: 4px;
}
.c-share__btn{
  display: inline-flex; align-items: center; gap: 6px;
  padding: 7px 14px;
  border-radius: 999px;
  font-family: var(--font-jp);
  font-weight: 700;
  font-size: 11.5px;
  background: #fff;
  border: 1px solid var(--rule);
  color: var(--ink-2);
  transition: transform .15s ease, background .2s ease, color .2s ease, border-color .2s ease;
}
.c-share__btn:hover{ transform: translateY(-1px) }
.c-share__btn--x:hover{ background: #111; color: #fff; border-color: #111 }
.c-share__btn--fb:hover{ background: #1877F2; color: #fff; border-color: #1877F2 }
.c-share__btn--line:hover{ background: #06C755; color: #fff; border-color: #06C755 }
.c-share__btn--copy:hover,
.c-share__btn--save:hover{ border-color: var(--coral); color: var(--coral) }
.c-share__btn[aria-pressed="true"]{
  background: var(--coral-soft);
  color: var(--coral);
  border-color: var(--coral-soft);
}
.c-share--end{
  margin-top: 24px;
  padding: 16px;
  background: var(--bg-soft);
  border-radius: var(--radius);
}

/* Table of Contents ---------------------------------------- */
.c-toc{
  background: #fff;
  border: 1px solid var(--rule);
  border-radius: var(--radius);
  padding: 16px 20px;
  margin: 0 0 32px;
  box-shadow: var(--shadow-sm);
}
.c-toc__head{
  display: flex; justify-content: space-between; align-items: center;
  cursor: pointer;
  list-style: none;
  font-family: var(--font-jp);
  font-weight: 700;
  font-size: 14px;
  color: var(--ink);
}
.c-toc__head::-webkit-details-marker{ display: none }
.c-toc__title{ display: inline-flex; align-items: center; gap: 8px }
.c-toc__caret{
  color: var(--coral);
  font-size: 14px;
  transition: transform .2s ease;
}
.c-toc[open] .c-toc__caret{ transform: rotate(180deg) }
.c-toc__list{
  margin-top: 14px;
  counter-reset: toc;
}
.c-toc__list > li{
  counter-increment: toc;
  padding: 6px 0;
  border-top: 1px dashed var(--rule);
  font-size: 13px;
  font-family: var(--font-jp);
}
.c-toc__list > li:first-child{ border-top: 0 }
.c-toc__list > li > a::before{
  content: counter(toc) ". ";
  color: var(--coral);
  font-weight: 700;
  font-family: var(--font-num);
  margin-right: 4px;
}
.c-toc__list a{
  color: var(--ink-2);
  transition: color .15s ease;
}
.c-toc__list a:hover{ color: var(--coral) }
.c-toc__list ol{
  margin: 6px 0 2px 18px;
  counter-reset: toc-sub;
}
.c-toc__list ol li{
  counter-increment: toc-sub;
  padding: 4px 0;
  font-size: 12px;
}
.c-toc__list ol li a::before{
  content: counter(toc) "-" counter(toc-sub) ". ";
  color: var(--muted);
  font-family: var(--font-num);
  margin-right: 4px;
}

/* Article body typography ---------------------------------- */
.p-article__body{
  max-width: 720px;
  font-size: 15px;
  line-height: 1.95;
  color: var(--ink);
}
.p-article__body > * + *{ margin-top: 1.1em }
.p-article__body h2{
  font-family: var(--font-jp);
  font-weight: 900;
  font-size: 22px;
  line-height: 1.5;
  color: var(--ink);
  margin: 2em 0 .8em;
  padding: 12px 0 12px 18px;
  border-left: 6px solid var(--coral);
  background: linear-gradient(90deg, var(--coral-soft) 0%, transparent 80%);
  border-radius: 4px;
  scroll-margin-top: 24px;
}
.p-article__body h2:first-child{ margin-top: 0 }
.p-article__body h3{
  font-family: var(--font-jp);
  font-weight: 700;
  font-size: 17px;
  line-height: 1.55;
  margin: 1.8em 0 .6em;
  padding-left: 14px;
  border-left: 4px solid var(--sage);
  scroll-margin-top: 24px;
}
.p-article__body h4{
  font-family: var(--font-jp);
  font-weight: 700;
  font-size: 15px;
  margin: 1.6em 0 .5em;
  color: var(--ink-2);
}
.p-article__body p{ margin: 0 }
.p-article__body strong{
  font-weight: 700;
  background: linear-gradient(transparent 70%, var(--yellow-soft) 70%);
  padding: 0 .1em;
}
.p-article__body em{
  font-style: normal;
  color: var(--coral);
  font-weight: 700;
}
.p-article__body a{
  color: var(--coral);
  text-decoration: underline;
  text-underline-offset: 3px;
  text-decoration-thickness: 1px;
}
.p-article__body a:hover{ text-decoration-thickness: 2px }
.p-article__body ul,
.p-article__body ol{
  padding-left: 1.5em;
  list-style: revert;
}
.p-article__body ul li,
.p-article__body ol li{ margin: .35em 0 }
.p-article__body ul li::marker{ color: var(--coral) }
.p-article__body ol li::marker{ color: var(--coral); font-family: var(--font-num); font-weight: 700 }

/* Article tables --------------------------------------------- */
/* 記事本文内の <table> を the_content フィルタで p-article__table-wrap に
   自動ラップしている。ここではラッパにカード装飾＋横スクロールを付与し、
   内側の <table> はブランドカラーで統一スタイル化する。 */
.p-article__table-wrap{
  margin: 1.8em 0;
  background: #fff;
  border: 1px solid var(--rule);
  border-radius: var(--radius);
  box-shadow: var(--shadow-sm);
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}
.p-article__body .p-article__table-wrap > table,
.p-article__body table{
  width: 100%;
  border-collapse: collapse;
  font-family: var(--font-jp);
  font-size: 13.5px;
  line-height: 1.75;
  color: var(--ink);
  margin: 0;
}
.p-article__body table caption{
  caption-side: top;
  padding: 12px 18px;
  text-align: left;
  font-weight: 700;
  font-size: 12.5px;
  color: var(--ink-2);
  background: var(--bg-soft);
  border-bottom: 1px solid var(--rule);
}
.p-article__body table th,
.p-article__body table td{
  padding: 13px 18px;
  text-align: left;
  vertical-align: top;
  border-bottom: 1px solid var(--rule);
}
.p-article__body table thead th{
  background: linear-gradient(180deg, var(--coral-soft), #FCEEE7);
  color: var(--ink);
  font-weight: 700;
  font-size: 13px;
  letter-spacing: .02em;
  white-space: nowrap;
  border-bottom: 2px solid var(--coral);
}
.p-article__body table thead th + th{
  border-left: 1px dashed rgba(240, 138, 112, .35);
}
.p-article__body table tbody th{
  background: var(--bg-soft);
  color: var(--coral);
  font-family: var(--font-jp);
  font-weight: 700;
  white-space: nowrap;
}
.p-article__body table tbody tr:nth-child(even) td{
  background: #FFFCF8;
}
.p-article__body table tbody tr:last-child th,
.p-article__body table tbody tr:last-child td{
  border-bottom: 0;
}
.p-article__body table strong{
  background: none;  /* 行内 <strong> のマーカーが table 内では邪魔になるため解除 */
  padding: 0;
  color: var(--coral);
}
.p-article__body table a{
  color: var(--coral);
  text-decoration: underline;
  text-underline-offset: 3px;
}

/* Mobile: 横スクロールを優先しつつセル内文字は折り返さない */
@media (max-width: 720px){
  .p-article__table-wrap{
    margin: 1.4em -4px;        /* コンテナ余白を少し相殺してテーブルを広く */
    border-radius: 12px;
  }
  .p-article__body table{
    width: max-content;
    min-width: 100%;
    font-size: 12.5px;
  }
  .p-article__body table th,
  .p-article__body table td{
    padding: 10px 14px;
    white-space: nowrap;
  }
  .p-article__body table thead th{
    font-size: 12px;
  }
}

/* Callout --------------------------------------------------- */
.c-callout{
  margin: 1.6em 0;
  padding: 16px 20px;
  border-radius: var(--radius);
  background: var(--sage-soft);
  border-left: 4px solid var(--sage);
  font-size: 13.5px;
  line-height: 1.85;
}
.c-callout p{ margin: 0 }
.c-callout__title{
  font-family: var(--font-jp);
  font-weight: 700;
  font-size: 13px;
  margin-bottom: 6px !important;
  color: var(--ink);
}
.c-callout--tip{ background: var(--yellow-soft); border-left-color: #E0B45A }
.c-callout--warn{ background: var(--coral-soft); border-left-color: var(--coral) }
.c-callout--info{ background: #E2EEF7; border-left-color: #5B97C2 }

/* Pull quote ------------------------------------------------ */
.c-pullquote{
  margin: 1.8em 0;
  padding: 22px 26px 22px 50px;
  background: #fff;
  border: 1px solid var(--rule);
  border-radius: var(--radius);
  position: relative;
  font-family: var(--font-jp);
  font-weight: 500;
  font-size: 16px;
  line-height: 1.85;
  color: var(--ink);
}
.c-pullquote::before{
  content: "\201C";
  position: absolute;
  left: 14px; top: 0;
  font-family: Georgia, serif;
  font-size: 60px;
  color: var(--coral);
  line-height: 1;
}
.c-pullquote p{ margin: 0 }

/* Figure ---------------------------------------------------- */
.c-figure{
  margin: 1.8em 0;
  text-align: center;
}
.c-figure img{
  width: 100%; height: auto;
  border-radius: var(--radius);
  box-shadow: var(--shadow-sm);
}
.c-figure figcaption{
  margin-top: 8px;
  font-size: 11.5px;
  color: var(--muted);
}

/* Table ----------------------------------------------------- */
.c-table-wrap{
  margin: 1.8em 0;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  border-radius: var(--radius);
  background: #fff;
  box-shadow: var(--shadow-sm);
}
.c-table{
  width: 100%;
  border-collapse: collapse;
  font-size: 13px;
  line-height: 1.7;
  font-family: var(--font-jp);
}
.c-table__caption{
  padding: 12px 16px;
  text-align: left;
  font-weight: 700;
  font-size: 12.5px;
  color: var(--ink-2);
  background: var(--bg-soft);
  border-bottom: 1px solid var(--rule);
}
.c-table th,
.c-table td{
  padding: 12px 14px;
  border-bottom: 1px solid var(--rule);
  vertical-align: top;
  text-align: left;
}
.c-table thead th{
  background: var(--bg-soft);
  font-weight: 700;
  font-size: 12.5px;
  color: var(--ink);
}
.c-table tbody th{
  background: #FFFCF8;
  font-weight: 700;
  white-space: nowrap;
  color: var(--coral);
  font-family: var(--font-num);
}
.c-table tbody tr:last-child th,
.c-table tbody tr:last-child td{ border-bottom: 0 }

/* Embed (responsive 16:9) ---------------------------------- */
.c-embed{ margin: 1.8em 0 }
.c-embed__inner{
  position: relative;
  width: 100%;
  aspect-ratio: 16 / 9;
  border-radius: var(--radius);
  overflow: hidden;
  box-shadow: var(--shadow-sm);
  background: #000;
}
.c-embed__inner iframe{
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  border: 0;
}
.c-embed__caption{
  margin-top: 8px !important;
  font-size: 11.5px;
  color: var(--muted);
  text-align: center;
}

/* Inline article card -------------------------------------- */
.c-inline-card{
  margin: 1.8em 0;
  padding: 14px 16px;
  background: var(--bg-soft);
  border-radius: var(--radius);
  border: 1px dashed var(--coral-2);
}
.c-inline-card__label{
  display: inline-block;
  font-family: var(--font-jp);
  font-weight: 700;
  font-size: 11px;
  color: var(--coral);
  background: #fff;
  padding: 3px 10px;
  border-radius: 999px;
  margin-bottom: 10px !important;
}
.c-inline-card__link{
  display: flex; gap: 14px; align-items: center;
}
.c-inline-card__link img{
  width: 100px; height: 75px;
  object-fit: cover;
  border-radius: 8px;
  flex-shrink: 0;
}
.c-inline-card__body{ flex: 1; min-width: 0 }
.c-inline-card__title{
  margin: 6px 0 0 !important;
  font-family: var(--font-jp);
  font-weight: 700;
  font-size: 13.5px;
  line-height: 1.55;
  color: var(--ink);
  text-decoration: none !important;
}
.c-inline-card__link:hover .c-inline-card__title{ color: var(--coral) }

/* Product / affiliate card --------------------------------- */
.c-product{
  display: flex; gap: 16px;
  margin: 1.8em 0;
  padding: 18px;
  background: #fff;
  border: 1px solid var(--rule);
  border-radius: var(--radius);
  box-shadow: var(--shadow-sm);
}
.c-product__img{
  flex-shrink: 0;
  width: 120px; height: 120px;
  border-radius: 10px;
  overflow: hidden;
  background: var(--bg-soft);
}
.c-product__img img{ width: 100%; height: 100%; object-fit: cover }
.c-product__body{ flex: 1; min-width: 0 }
.c-product__cat{
  display: inline-block;
  font-family: var(--font-jp);
  font-weight: 700;
  font-size: 10.5px;
  color: var(--coral);
  background: var(--coral-soft);
  padding: 2px 10px;
  border-radius: 999px;
  margin: 0 !important;
}
.c-product__name{
  font-family: var(--font-jp);
  font-weight: 700;
  font-size: 15px;
  margin: 8px 0 6px !important;
  color: var(--ink);
}
.c-product__desc{
  font-size: 12.5px;
  color: var(--ink-2);
  line-height: 1.75;
  margin: 0 0 10px !important;
}
.c-product__actions{
  display: flex; align-items: center; gap: 12px;
  flex-wrap: wrap;
}
.c-product__link{
  display: inline-flex; align-items: center;
  background: var(--coral);
  color: #fff !important;
  padding: 8px 18px;
  border-radius: 999px;
  font-family: var(--font-jp);
  font-weight: 700;
  font-size: 12px;
  text-decoration: none !important;
  box-shadow: 0 4px 10px rgba(240,138,112,.25);
}
.c-product__link:hover{ background: #e87b62 }
.c-product__note{
  font-size: 10.5px;
  color: var(--muted);
}

/* FAQ ------------------------------------------------------- */
.c-faq{
  margin: 1.6em 0;
  display: flex; flex-direction: column;
  gap: 10px;
}
.c-faq__item{
  background: #fff;
  border: 1px solid var(--rule);
  border-radius: var(--radius);
  overflow: hidden;
}
.c-faq__q{
  display: flex; align-items: flex-start; gap: 10px;
  padding: 14px 18px;
  cursor: pointer;
  list-style: none;
  font-family: var(--font-jp);
  font-weight: 700;
  font-size: 14px;
  color: var(--ink);
  position: relative;
}
.c-faq__q::-webkit-details-marker{ display: none }
.c-faq__q span{
  color: var(--coral);
  font-family: var(--font-num);
  font-weight: 700;
  flex-shrink: 0;
}
.c-faq__q::after{
  content: "＋";
  position: absolute;
  right: 18px; top: 50%;
  transform: translateY(-50%);
  color: var(--coral);
  font-family: var(--font-num);
  font-size: 18px;
  font-weight: 700;
  transition: transform .2s ease;
}
.c-faq__item[open] .c-faq__q::after{ content: "−"; transform: translateY(-50%) }
.c-faq__a{
  padding: 0 18px 16px 36px;
  font-size: 13.5px;
  line-height: 1.85;
  color: var(--ink-2);
}
.c-faq__a p{ margin: 0 }

/* In-article (multi-page) pagination ----------------------- */
.c-page-pagination{
  margin: 2em 0 0 !important;
  padding: 18px 20px;
  background: var(--bg-soft);
  border-radius: var(--radius);
  text-align: center;
}
.c-page-pagination__label{
  margin: 0 0 12px !important;
  font-size: 12px;
  color: var(--muted);
  font-family: var(--font-jp);
}
.c-page-pagination__list{
  display: inline-flex; gap: 8px;
  margin: 0 0 14px;
  padding: 0;
}
.c-page-pagination__list li{ list-style: none }
.c-page-pagination__list a,
.c-page-pagination__list span{
  display: inline-flex; align-items: center; justify-content: center;
  width: 36px; height: 36px;
  border-radius: 50%;
  background: #fff;
  border: 1px solid var(--rule);
  font-family: var(--font-num);
  font-weight: 700;
  font-size: 13px;
  color: var(--ink-2);
  text-decoration: none !important;
}
.c-page-pagination__list a:hover{ border-color: var(--coral); color: var(--coral) }
.c-page-pagination__list .is-current span{
  background: var(--coral);
  color: #fff;
  border-color: var(--coral);
}
.c-page-pagination__next{
  display: inline-flex; align-items: center; gap: 6px;
  background: var(--coral);
  color: #fff !important;
  padding: 9px 22px;
  border-radius: 999px;
  font-family: var(--font-jp);
  font-weight: 700;
  font-size: 12.5px;
  text-decoration: none !important;
  box-shadow: 0 4px 10px rgba(240,138,112,.25);
}
.c-page-pagination__next:hover{ background: #e87b62 }

/* Article footer (tags, references, supervisor, author) ---- */
.p-article__footer{
  margin-top: 36px;
  padding-top: 24px;
  border-top: 1px dashed var(--rule);
}
.p-article__tags{
  display: flex; flex-wrap: wrap; align-items: center;
  gap: 8px 12px;
  margin-bottom: 18px;
}
.p-article__tags-label{
  font-family: var(--font-jp);
  font-weight: 700;
  font-size: 12px;
  color: var(--muted);
}
.c-tag-list{
  display: flex; flex-wrap: wrap; gap: 6px;
  padding: 0;
}
.c-tag-list li{ list-style: none }
.c-tag-list a{
  display: inline-block;
  padding: 5px 12px;
  background: #fff;
  border: 1px solid var(--rule);
  border-radius: 999px;
  font-size: 11.5px;
  color: var(--ink-2);
  font-family: var(--font-jp);
  transition: color .15s ease, border-color .15s ease;
}
.c-tag-list a:hover{ color: var(--coral); border-color: var(--coral) }

.p-article__updated{
  margin: 18px 0;
  padding: 10px 14px;
  font-size: 11.5px;
  color: var(--muted);
  background: var(--bg-soft);
  border-radius: 8px;
}
.p-article__disclaimer{
  margin: 20px 0;
  padding: 14px 18px;
  background: #FFF8F2;
  border: 1px solid var(--coral-soft);
  border-radius: var(--radius);
  font-size: 12px;
  color: var(--ink-2);
  line-height: 1.85;
}
.p-article__disclaimer p{ margin: 0 }

/* References ------------------------------------------------ */
.p-reference{
  margin: 26px 0;
  padding: 18px 20px;
  background: #fff;
  border: 1px solid var(--rule);
  border-radius: var(--radius);
}
.p-reference__title{
  font-family: var(--font-jp);
  font-weight: 700;
  font-size: 14px;
  margin: 0 0 10px;
  color: var(--ink);
}
.p-reference__list{
  margin: 0;
  padding-left: 1.4em;
  font-size: 12px;
  line-height: 1.85;
  color: var(--ink-2);
  list-style: decimal;
}
.p-reference__list li{ margin: .3em 0 }
.p-reference__list a{
  color: var(--coral);
  text-decoration: underline;
  word-break: break-all;
}

/* Supervisor / Author boxes (shared shape) ----------------- */
.p-supervisor,
.p-author-box{
  margin: 22px 0;
  padding: 20px;
  border-radius: var(--radius);
  background: linear-gradient(180deg, #FFF6EE 0%, #fff 100%);
  border: 1px solid var(--rule);
}
.p-supervisor__label,
.p-author-box__role{
  display: inline-block;
  font-family: var(--font-jp);
  font-weight: 700;
  font-size: 11px;
  color: var(--coral);
  background: var(--coral-soft);
  padding: 3px 12px;
  border-radius: 999px;
  margin: 0 0 12px;
}
.p-supervisor__body,
.p-author-box{
  display: flex; gap: 16px; align-items: flex-start;
}
.p-author-box__avatar,
.p-supervisor__avatar{
  width: 64px; height: 64px;
  border-radius: 50%;
  object-fit: cover;
  flex-shrink: 0;
}
.p-supervisor__info,
.p-author-box__body{ flex: 1; min-width: 0 }
.p-supervisor__name,
.p-author-box__name{
  font-family: var(--font-jp);
  font-weight: 700;
  font-size: 15px;
  color: var(--ink);
  margin: 0 0 2px;
}
.p-supervisor__role{
  font-size: 11.5px; color: var(--muted);
  margin: 0 0 6px;
  font-family: var(--font-jp);
}
.p-supervisor__bio,
.p-author-box__bio{
  font-size: 12.5px;
  line-height: 1.85;
  color: var(--ink-2);
  margin: 0 0 8px;
}
.p-author-box__socials{
  display: flex; gap: 10px;
  color: var(--ink-2);
}
.p-author-box__socials a{
  width: 28px; height: 28px;
  border-radius: 50%;
  border: 1px solid var(--rule);
  display: grid; place-items: center;
}
.p-author-box__socials a:hover{ color: var(--coral); border-color: var(--coral) }

/* Prev / Next ---------------------------------------------- */
.c-prev-next{
  display: grid; grid-template-columns: 1fr 1fr; gap: 12px;
  margin: 30px 0;
}
.c-prev-next__item{
  display: flex; flex-direction: column; gap: 6px;
  padding: 14px 18px;
  background: #fff;
  border: 1px solid var(--rule);
  border-radius: var(--radius);
  text-decoration: none;
  transition: transform .15s ease, border-color .2s ease;
}
.c-prev-next__item:hover{
  border-color: var(--coral);
  transform: translateY(-2px);
  box-shadow: var(--shadow-sm);
}
.c-prev-next__item--next{ text-align: right }
.c-prev-next__label{
  font-size: 11px;
  color: var(--coral);
  font-family: var(--font-jp);
  font-weight: 700;
}
.c-prev-next__title{
  font-family: var(--font-jp);
  font-weight: 700;
  font-size: 13px;
  line-height: 1.55;
  color: var(--ink);
}

/* Related articles section --------------------------------- */
.p-related{
  margin: 40px 0 30px;
  padding-top: 28px;
  border-top: 1px solid var(--rule);
}

/* Comments placeholder ------------------------------------- */
.p-comments{
  margin: 36px 0 0;
  padding-top: 28px;
  border-top: 1px solid var(--rule);
}
.p-comments__placeholder{
  margin-top: 14px;
  padding: 24px;
  text-align: center;
  background: var(--bg-soft);
  border-radius: var(--radius);
  font-size: 12.5px;
  color: var(--ink-2);
}
.p-comments__placeholder a{ color: var(--coral); text-decoration: underline }

/* Pagination (archive style) ------------------------------- */
.c-pagination{
  margin: 30px 0;
  padding: 24px 20px;
  background: #fff;
  border: 1px solid var(--rule);
  border-radius: var(--radius);
  text-align: center;
}
.c-pagination__label{
  margin: 0 0 14px;
  font-size: 12px;
  color: var(--muted);
  font-family: var(--font-jp);
}
.c-pagination__list{
  display: inline-flex; flex-wrap: wrap; justify-content: center;
  gap: 6px;
  padding: 0;
}
.c-pagination__list li{ list-style: none }
.c-pagination__num,
.c-pagination__arrow{
  display: inline-flex; align-items: center; justify-content: center;
  min-width: 36px; height: 36px;
  padding: 0 10px;
  border-radius: 999px;
  background: var(--bg-soft);
  font-family: var(--font-num);
  font-weight: 700;
  font-size: 13px;
  color: var(--ink-2);
  text-decoration: none !important;
  border: 1px solid transparent;
  transition: background .2s ease, color .2s ease;
}
.c-pagination__num:hover,
.c-pagination__arrow:hover{
  background: var(--coral-soft);
  color: var(--coral);
}
.c-pagination__num.is-current{
  background: var(--coral);
  color: #fff;
}
.c-pagination__ellipsis{
  display: inline-flex; align-items: center; justify-content: center;
  min-width: 24px; height: 36px;
  color: var(--muted);
}

/* Mobile floating share/save FAB --------------------------- */
.c-share-fab{
  position: fixed;
  left: 50%;
  bottom: 16px;
  transform: translateX(-50%);
  display: none;
  gap: 8px;
  padding: 8px;
  background: rgba(255, 255, 255, .96);
  backdrop-filter: blur(8px);
  border: 1px solid var(--rule);
  border-radius: 999px;
  box-shadow: var(--shadow-md);
  z-index: 40;
}
.c-share-fab__btn{
  display: inline-flex; flex-direction: column; align-items: center;
  justify-content: center;
  gap: 2px;
  padding: 6px 12px;
  border-radius: 999px;
  background: transparent;
  color: var(--ink-2);
  font-family: var(--font-jp);
  font-weight: 700;
  font-size: 10px;
  text-decoration: none;
}
.c-share-fab__btn:active{ background: var(--bg-soft) }
.c-share-fab__btn[aria-pressed="true"]{ color: var(--coral) }

/* Toast ----------------------------------------------------- */
.c-toast{
  position: fixed;
  left: 50%;
  bottom: 80px;
  transform: translate(-50%, 12px);
  background: var(--ink);
  color: #fff;
  padding: 10px 18px;
  border-radius: 999px;
  font-family: var(--font-jp);
  font-weight: 700;
  font-size: 12.5px;
  opacity: 0;
  pointer-events: none;
  transition: opacity .25s ease, transform .25s ease;
  z-index: 60;
  box-shadow: var(--shadow-md);
}
.c-toast.is-visible{
  opacity: 1;
  transform: translate(-50%, 0);
}

/* Tag cloud (sidebar) -------------------------------------- */
.c-tag-cloud{
  display: flex; flex-wrap: wrap; gap: 6px;
  padding: 0;
}
.c-tag-cloud li{ list-style: none }
.c-tag-cloud a{
  display: inline-block;
  font-size: 11px;
  padding: 4px 10px;
  background: var(--bg-soft);
  border-radius: 999px;
  color: var(--ink-2);
  font-family: var(--font-jp);
}
.c-tag-cloud a:hover{ background: var(--coral-soft); color: var(--coral) }

/* Responsive ----------------------------------------------- */
@media (max-width: 1080px){
  .p-article__layout{ grid-template-columns: 1fr 260px; gap: 28px }
  .p-article__title{ font-size: 28px }
}

@media (max-width: 920px){
  .p-article__layout{ grid-template-columns: 1fr; gap: 36px }
  .p-article__body{ max-width: 100%; font-size: 14.5px }
  .p-article__title{ font-size: 24px }
  .p-article__body h2{ font-size: 19px }
  .p-article__body h3{ font-size: 16px }
}

@media (max-width: 720px){
  .p-article{ padding: 4px 0 40px }
  .c-breadcrumb{ font-size: 11px }
  .c-breadcrumb__list [aria-current="page"]{ max-width: 60vw }

  .p-article__title{ font-size: 21px }
  .p-article__lead{ font-size: 13.5px; padding-left: 12px }
  .p-article__body{ font-size: 14px; line-height: 1.9 }
  .p-article__body h2{ font-size: 18px; padding: 10px 0 10px 14px }
  .p-article__body h3{ font-size: 15px }

  .p-article__bylines{ flex-direction: column; gap: 12px }
  .c-byline + .c-byline{ padding-left: 0; padding-top: 12px; border-left: 0; border-top: 1px dashed var(--rule) }

  .c-share{ gap: 6px }
  .c-share__btn{ padding: 6px 10px; font-size: 11px }
  .c-share__btn span{ display: none }
  .c-share__btn--copy span,
  .c-share__btn--save span{ display: none }

  .c-toc{ padding: 14px 16px }

  .c-callout{ padding: 14px 16px; font-size: 13px }
  .c-pullquote{ padding: 18px 18px 18px 42px; font-size: 14.5px }
  .c-pullquote::before{ font-size: 48px; left: 10px }

  .c-table{ font-size: 12px }
  .c-table th, .c-table td{ padding: 10px 12px }

  .c-product{ flex-direction: column; padding: 14px }
  .c-product__img{ width: 100%; height: 180px }

  .c-inline-card__link{ flex-direction: column; align-items: flex-start; gap: 10px }
  .c-inline-card__link img{ width: 100%; height: 160px }

  .p-supervisor__body,
  .p-author-box{ flex-direction: column; gap: 12px; align-items: flex-start }
  .p-author-box__avatar, .p-supervisor__avatar{ width: 56px; height: 56px }

  .c-prev-next{ grid-template-columns: 1fr }
  .c-prev-next__item--next{ text-align: left }

  .c-page-pagination{ padding: 16px }
  .c-pagination{ padding: 18px 12px }
  .c-pagination__num, .c-pagination__arrow{ min-width: 32px; height: 32px; font-size: 12px }

  /* Mobile FAB */
  .c-share-fab{ display: inline-flex }
  /* 既存の to-top と被るので非表示に */
  .site-footer .to-top{ display: none }
}

@media (max-width: 480px){
  .p-article__title{ font-size: 19px; line-height: 1.5 }
  .p-article__body h2{ font-size: 17px }
  .c-share__label{ display: none }
  .c-share-fab__btn{ padding: 6px 10px }
  .c-share-fab__btn span{ font-size: 9.5px }
}

/* ============================================================
   FAQ / About — shared page hero, sections, CTA
   ============================================================ */

/* Page hero (shared) ---------------------------------------- */
.p-page-hero{
  position: relative;
  padding: 50px 0 56px;
  text-align: center;
  overflow: hidden;
}
.p-page-hero--faq{ background: linear-gradient(180deg, var(--bg-soft) 0%, var(--bg) 100%) }
.p-page-hero--about{ background: linear-gradient(180deg, #FFF1E2 0%, var(--bg) 100%) }
.p-page-hero__inner{ position: relative; z-index: 2 }
.p-page-hero__deco{
  position: absolute;
  pointer-events: none;
  user-select: none;
  z-index: 1;
}
.p-page-hero__deco--1{ width: 110px; left: 4%; top: 20%; opacity: .55; transform: rotate(-8deg) }
.p-page-hero__deco--2{ width: 70px; right: 8%; top: 14%; opacity: .7 }
.p-page-hero__deco--3{ width: 90px; right: 5%; bottom: -10px; opacity: .55 }
.p-page-hero__tag{
  display: inline-block;
  margin: 0 0 12px;
  padding: 4px 14px;
  background: #fff;
  color: var(--coral);
  border-radius: 999px;
  font-family: var(--font-num);
  font-weight: 700;
  font-size: 11.5px;
  letter-spacing: .12em;
  box-shadow: var(--shadow-sm);
}
.p-page-hero__title{
  margin: 0 0 18px;
  font-family: var(--font-jp);
  font-weight: 900;
  font-size: 36px;
  line-height: 1.4;
  color: var(--ink);
  letter-spacing: .01em;
}
.p-page-hero__lead{
  max-width: 640px;
  margin: 0 auto;
  font-size: 14px;
  line-height: 2;
  color: var(--ink-2);
}

/* Section heading (shared) ---------------------------------- */
.p-section-head{
  text-align: center;
  margin-bottom: 32px;
}
.p-section-tag{
  display: inline-block;
  margin: 0 0 10px;
  padding: 3px 14px;
  background: var(--coral-soft);
  color: var(--coral);
  border-radius: 999px;
  font-family: var(--font-num);
  font-weight: 700;
  font-size: 10.5px;
  letter-spacing: .14em;
}
.p-section-title{
  margin: 0 0 12px;
  font-family: var(--font-jp);
  font-weight: 900;
  font-size: 26px;
  line-height: 1.5;
  color: var(--ink);
}
.p-section-desc{
  max-width: 640px;
  margin: 0 auto;
  font-size: 13px;
  line-height: 1.95;
  color: var(--ink-2);
}

/* CTA (shared) ---------------------------------------------- */
.p-cta{ padding: 50px 0 60px }
.p-cta__inner{
  position: relative;
  background: linear-gradient(135deg, var(--coral-soft) 0%, var(--yellow-soft) 100%);
  border-radius: var(--radius-lg);
  padding: 40px 32px;
  text-align: center;
  overflow: hidden;
}
.p-cta__deco{
  position: absolute;
  right: 24px; bottom: 14px;
  width: 90px;
  opacity: .65;
  pointer-events: none;
}
.p-cta__title{
  margin: 0 0 10px;
  font-family: var(--font-jp);
  font-weight: 900;
  font-size: 22px;
  line-height: 1.55;
  color: var(--ink);
}
.p-cta__lead{
  max-width: 540px;
  margin: 0 auto 22px;
  font-size: 13px;
  line-height: 1.95;
  color: var(--ink-2);
}
.p-cta__actions{
  display: flex; flex-wrap: wrap; justify-content: center;
  gap: 10px;
}

/* ============================================================
   FAQ Page
   ============================================================ */
.p-faq{ padding: 14px 0 0 }

.p-faq-toc{
  margin: 0 auto 36px;
  padding: 22px;
  background: #fff;
  border-radius: var(--radius);
  box-shadow: var(--shadow-sm);
  text-align: center;
}
.p-faq-toc__label{
  margin: 0 0 14px;
  font-family: var(--font-jp);
  font-weight: 700;
  font-size: 12.5px;
  color: var(--muted);
  letter-spacing: .04em;
}
.p-faq-toc__list{
  display: flex; flex-wrap: wrap; justify-content: center;
  gap: 8px;
  padding: 0;
}
.p-faq-toc__list li{ list-style: none }
.p-faq-toc__list a{
  display: inline-block;
  padding: 7px 16px;
  background: var(--bg-soft);
  border-radius: 999px;
  font-family: var(--font-jp);
  font-weight: 700;
  font-size: 12px;
  color: var(--ink-2);
  transition: background .2s ease, color .2s ease;
}
.p-faq-toc__list a:hover{ background: var(--coral); color: #fff }

.p-faq-section{
  margin: 0 0 44px;
  scroll-margin-top: 24px;
}
.p-faq-section__head{
  margin: 0 0 18px;
  padding: 18px 22px;
  background: linear-gradient(90deg, var(--coral-soft) 0%, transparent 90%);
  border-left: 6px solid var(--coral);
  border-radius: 6px;
}
.p-faq-section__no{
  display: inline-block;
  font-family: var(--font-num);
  font-weight: 700;
  font-size: 12px;
  color: var(--coral);
  letter-spacing: .1em;
  margin-bottom: 4px;
}
.p-faq-section__title{
  margin: 0 0 6px;
  font-family: var(--font-jp);
  font-weight: 900;
  font-size: 20px;
  line-height: 1.5;
  color: var(--ink);
}
.p-faq-section__desc{
  margin: 0;
  font-size: 12.5px;
  line-height: 1.85;
  color: var(--ink-2);
}

/* FAQ items reuse .c-faq from article styles, with adjustments */
.p-faq-section .c-faq__a{
  font-size: 13.5px;
  line-height: 1.95;
}
.p-faq-section .c-faq__a p + p,
.p-faq-section .c-faq__a p + ul,
.p-faq-section .c-faq__a ul + p{ margin-top: 8px }
.p-faq-section .c-faq__a ul{
  margin: 0;
  padding-left: 1.4em;
  list-style: disc;
}
.p-faq-section .c-faq__a ul li{ margin: .25em 0 }
.p-faq-section .c-faq__a ul li::marker{ color: var(--coral) }
.p-faq-section .c-faq__a a{
  color: var(--coral);
  text-decoration: underline;
  text-underline-offset: 3px;
}
.p-faq-section .c-faq__a strong{
  font-weight: 700;
  background: linear-gradient(transparent 70%, var(--yellow-soft) 70%);
  padding: 0 .1em;
}

/* ============================================================
   About Page
   ============================================================ */
.p-mission,
.p-policy,
.p-strength,
.p-team,
.p-supervisors,
.p-timeline{ padding: 50px 0 }

.p-mission__head{
  text-align: center;
  margin-bottom: 36px;
}
.p-mission__list{
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
  padding: 0;
  counter-reset: mission;
}
.p-mission__item{
  list-style: none;
  position: relative;
  padding: 28px 24px 26px;
  background: #fff;
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm);
  border: 1px solid var(--rule);
}
.p-mission__no{
  display: inline-block;
  font-family: var(--font-num);
  font-weight: 700;
  font-size: 28px;
  color: var(--coral);
  line-height: 1;
  margin-bottom: 12px;
}
.p-mission__heading{
  margin: 0 0 10px;
  font-family: var(--font-jp);
  font-weight: 700;
  font-size: 17px;
  color: var(--ink);
  line-height: 1.55;
}
.p-mission__body{
  margin: 0;
  font-size: 13px;
  line-height: 1.95;
  color: var(--ink-2);
}

/* Policy ---------------------------------------------------- */
.p-policy{ background: var(--bg-soft) }
.p-policy__grid{
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 18px;
}
.p-policy__card{
  padding: 22px 20px;
  background: #fff;
  border-radius: var(--radius);
  box-shadow: var(--shadow-sm);
  text-align: center;
}
.p-policy__icon{
  width: 52px; height: 52px;
  margin: 0 auto 12px;
  background: var(--bg-soft);
  border-radius: 50%;
  display: grid; place-items: center;
}
.p-policy__heading{
  margin: 0 0 8px;
  font-family: var(--font-jp);
  font-weight: 700;
  font-size: 15px;
  color: var(--ink);
  line-height: 1.55;
}
.p-policy__body{
  margin: 0;
  font-size: 12px;
  line-height: 1.9;
  color: var(--ink-2);
}

/* Strength -------------------------------------------------- */
.p-strength__grid{
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
}
.p-strength__card{
  position: relative;
  padding: 32px 24px 26px;
  border-radius: var(--radius-lg);
  background: linear-gradient(180deg, #FFF6EE 0%, #fff 100%);
  border: 1px solid var(--rule);
  box-shadow: var(--shadow-sm);
}
.p-strength__num{
  position: absolute;
  right: 22px; top: 22px;
  margin: 0;
  font-family: var(--font-num);
  font-weight: 700;
  font-size: 32px;
  color: var(--coral-2);
  opacity: .8;
  line-height: 1;
}
.p-strength__heading{
  margin: 0 0 12px;
  font-family: var(--font-jp);
  font-weight: 700;
  font-size: 17px;
  line-height: 1.6;
  color: var(--ink);
}
.p-strength__body{
  margin: 0;
  font-size: 12.5px;
  line-height: 1.95;
  color: var(--ink-2);
}

/* Team ------------------------------------------------------ */
.p-team__grid{
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 20px;
}
.p-team__card{
  padding: 22px 20px;
  background: #fff;
  border-radius: var(--radius);
  text-align: center;
  box-shadow: var(--shadow-sm);
  transition: transform .2s ease, box-shadow .2s ease;
}
.p-team__card:hover{
  transform: translateY(-2px);
  box-shadow: var(--shadow-md);
}
.p-team__avatar{
  width: 96px; height: 96px;
  border-radius: 50%;
  object-fit: cover;
  margin: 0 auto 14px;
  display: block;
  border: 4px solid #fff;
  box-shadow: var(--shadow-sm);
}
.p-team__role{
  margin: 0 0 4px;
  font-family: var(--font-num);
  font-weight: 700;
  font-size: 10.5px;
  color: var(--coral);
  letter-spacing: .08em;
}
.p-team__name{
  margin: 0 0 10px;
  font-family: var(--font-jp);
  font-weight: 700;
  font-size: 15px;
  color: var(--ink);
}
.p-team__bio{
  margin: 0;
  font-size: 11.5px;
  line-height: 1.9;
  color: var(--ink-2);
  text-align: left;
}

/* Supervisors ----------------------------------------------- */
.p-supervisors{ background: var(--bg-soft) }
.p-supervisors__grid{
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
}
.p-supervisors__card{
  padding: 24px 22px;
  background: #fff;
  border-radius: var(--radius);
  box-shadow: var(--shadow-sm);
  border: 1px solid var(--rule);
}
.p-supervisors__avatar{
  width: 80px; height: 80px;
  border-radius: 50%;
  object-fit: cover;
  margin: 0 0 12px;
  display: block;
  border: 3px solid var(--coral-soft);
}
.p-supervisors__field{
  display: inline-block;
  margin: 0 0 6px;
  padding: 3px 10px;
  background: var(--sage-soft);
  color: #3f7e8b;
  border-radius: 999px;
  font-family: var(--font-jp);
  font-weight: 700;
  font-size: 10.5px;
}
.p-supervisors__name{
  margin: 0 0 10px;
  font-family: var(--font-jp);
  font-weight: 700;
  font-size: 16px;
  color: var(--ink);
}
.p-supervisors__bio{
  margin: 0;
  font-size: 12px;
  line-height: 1.9;
  color: var(--ink-2);
}
.p-supervisors__note{
  max-width: 640px;
  margin: 22px auto 0;
  text-align: center;
  font-size: 11px;
  color: var(--muted);
}

/* Timeline -------------------------------------------------- */
.p-timeline__list{
  position: relative;
  max-width: 720px;
  margin: 0 auto;
  padding: 0 0 0 24px;
}
.p-timeline__list::before{
  content: "";
  position: absolute;
  left: 6px; top: 8px; bottom: 8px;
  width: 2px;
  background: var(--coral-soft);
  border-radius: 2px;
}
.p-timeline__item{
  position: relative;
  list-style: none;
  padding: 0 0 24px 16px;
}
.p-timeline__item::before{
  content: "";
  position: absolute;
  left: -24px; top: 6px;
  width: 14px; height: 14px;
  background: var(--coral);
  border: 3px solid #fff;
  border-radius: 50%;
  box-shadow: 0 0 0 1px var(--coral-soft);
}
.p-timeline__item--upcoming::before{
  background: #fff;
  border-color: var(--coral);
  box-shadow: 0 0 0 1px var(--coral-soft);
}
.p-timeline__date{
  display: inline-block;
  margin-bottom: 4px;
  font-family: var(--font-num);
  font-weight: 700;
  font-size: 12px;
  color: var(--coral);
  letter-spacing: .04em;
}
.p-timeline__heading{
  margin: 0 0 6px;
  font-family: var(--font-jp);
  font-weight: 700;
  font-size: 15px;
  color: var(--ink);
}
.p-timeline__body{
  margin: 0;
  font-size: 12.5px;
  line-height: 1.9;
  color: var(--ink-2);
}

/* Responsive — FAQ / About --------------------------------- */
@media (max-width: 1080px){
  .p-policy__grid{ grid-template-columns: repeat(2, 1fr) }
  .p-team__grid{ grid-template-columns: repeat(2, 1fr) }
}

@media (max-width: 920px){
  .p-page-hero{ padding: 40px 0 44px }
  .p-page-hero__title{ font-size: 30px }
  .p-page-hero__deco--1{ width: 80px; opacity: .4 }
  .p-page-hero__deco--2{ width: 56px }
  .p-page-hero__deco--3{ width: 70px }

  .p-section-title{ font-size: 22px }

  .p-mission__list{ grid-template-columns: 1fr; gap: 14px }
  .p-strength__grid{ grid-template-columns: 1fr; gap: 14px }
  .p-supervisors__grid{ grid-template-columns: 1fr; gap: 14px }
  .p-team__grid{ grid-template-columns: repeat(2, 1fr); gap: 14px }
}

@media (max-width: 720px){
  .p-page-hero{ padding: 32px 0 36px }
  .p-page-hero__title{ font-size: 24px; line-height: 1.45 }
  .p-page-hero__lead{ font-size: 13px }
  .p-page-hero__deco--1{ display: none }

  .p-section-title{ font-size: 19px }
  .p-section-desc{ font-size: 12.5px }

  .p-faq-toc{ padding: 16px }
  .p-faq-toc__list{ gap: 6px }
  .p-faq-toc__list a{ padding: 6px 12px; font-size: 11.5px }

  .p-faq-section{ margin-bottom: 32px }
  .p-faq-section__head{ padding: 14px 16px }
  .p-faq-section__title{ font-size: 17px }

  .p-mission,
  .p-policy,
  .p-strength,
  .p-team,
  .p-supervisors,
  .p-timeline{ padding: 36px 0 }

  .p-policy__grid{ grid-template-columns: 1fr }
  .p-team__grid{ grid-template-columns: 1fr }

  .p-cta{ padding: 30px 0 40px }
  .p-cta__inner{ padding: 28px 20px }
  .p-cta__title{ font-size: 18px }
  .p-cta__deco{ width: 64px; right: 10px; bottom: 8px; opacity: .5 }

  .p-timeline__list{ padding-left: 18px }
  .p-timeline__item{ padding-left: 12px }
  .p-timeline__item::before{ left: -18px }
}

@media (max-width: 480px){
  .p-page-hero__title{ font-size: 20px }
  .p-section-title{ font-size: 17px }
  .p-faq-section__title{ font-size: 15.5px }
  .p-cta__actions .btn,
  .p-cta__actions .ghost-btn{ width: 100%; justify-content: center }
}

/* ============================================================
   Feature page
   ============================================================ */
.p-page-hero--feature{ background: linear-gradient(180deg, var(--yellow-soft) 0%, var(--bg) 100%) }
.p-page-hero--contact{ background: linear-gradient(180deg, var(--coral-soft) 0%, var(--bg) 100%) }
.p-page-hero--legal{ background: linear-gradient(180deg, #F4ECE0 0%, var(--bg) 100%) }
.p-page-hero--sitemap{ background: linear-gradient(180deg, var(--sage-soft) 0%, var(--bg) 100%) }

/* Pickup feature ------------------------------------------- */
.p-feature-pickup{ padding: 16px 0 36px }
.p-feature-pickup__card{
  display: grid;
  grid-template-columns: 1.1fr 1fr;
  gap: 0;
  background: #fff;
  border-radius: var(--radius-lg);
  overflow: hidden;
  box-shadow: var(--shadow-md);
  border: 1px solid var(--rule);
}
.p-feature-pickup__media{
  position: relative;
  overflow: hidden;
  min-height: 320px;
}
.p-feature-pickup__media img{
  width: 100%; height: 100%;
  object-fit: cover;
}
.p-feature-pickup__badge{
  position: absolute;
  top: 18px; left: 18px;
  background: var(--coral);
  color: #fff;
  font-family: var(--font-num);
  font-weight: 700;
  font-size: 11px;
  letter-spacing: .14em;
  padding: 5px 14px;
  border-radius: 999px;
  box-shadow: 0 4px 10px rgba(240,138,112,.3);
}
.p-feature-pickup__body{
  padding: 32px 34px;
  display: flex; flex-direction: column;
}
.p-feature-pickup__season{
  display: inline-block;
  font-family: var(--font-jp);
  font-weight: 700;
  font-size: 11.5px;
  color: var(--coral);
  background: var(--coral-soft);
  padding: 3px 12px;
  border-radius: 999px;
  margin-bottom: 12px;
  align-self: flex-start;
}
.p-feature-pickup__title{
  margin: 0 0 14px;
  font-family: var(--font-jp);
  font-weight: 900;
  font-size: 24px;
  line-height: 1.5;
  color: var(--ink);
}
.p-feature-pickup__desc{
  margin: 0 0 16px;
  font-size: 13px;
  line-height: 1.95;
  color: var(--ink-2);
}
.p-feature-pickup__list{
  margin: 0 0 18px;
  padding: 0;
  border-top: 1px dashed var(--rule);
}
.p-feature-pickup__list li{
  list-style: none;
  border-bottom: 1px dashed var(--rule);
  padding: 8px 0 8px 22px;
  position: relative;
  font-size: 12.5px;
  font-family: var(--font-jp);
}
.p-feature-pickup__list li::before{
  content: "";
  position: absolute;
  left: 4px; top: 50%;
  width: 8px; height: 8px;
  background: var(--coral);
  border-radius: 50%;
  transform: translateY(-50%);
}
.p-feature-pickup__list a{
  color: var(--ink-2);
  transition: color .15s ease;
}
.p-feature-pickup__list a:hover{ color: var(--coral) }
.p-feature-pickup__count{
  margin: 10px 0 0;
  font-size: 11px;
  color: var(--muted);
  font-family: var(--font-num);
}

/* Feature grid --------------------------------------------- */
.p-feature{ padding: 36px 0 60px }
.p-feature__grid{
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 22px;
}
.p-feature__card{
  display: flex; flex-direction: column;
  background: #fff;
  border-radius: var(--radius-lg);
  overflow: hidden;
  box-shadow: var(--shadow-sm);
  transition: transform .2s ease, box-shadow .2s ease;
}
.p-feature__card:hover{
  transform: translateY(-3px);
  box-shadow: var(--shadow-md);
}
.p-feature__media{
  position: relative;
  aspect-ratio: 16/10;
  overflow: hidden;
}
.p-feature__media img{
  width: 100%; height: 100%;
  object-fit: cover;
  transition: transform .4s ease;
}
.p-feature__card:hover .p-feature__media img{ transform: scale(1.04) }
.p-feature__count{
  position: absolute;
  bottom: 12px; right: 12px;
  background: rgba(255,255,255,.92);
  color: var(--ink);
  font-family: var(--font-num);
  font-weight: 700;
  font-size: 11px;
  padding: 4px 10px;
  border-radius: 999px;
}
.p-feature__body{
  padding: 18px 20px 20px;
  display: flex; flex-direction: column;
  flex: 1;
}
.p-feature__season{
  display: inline-block;
  font-family: var(--font-jp);
  font-weight: 700;
  font-size: 10.5px;
  color: var(--coral);
  margin-bottom: 6px;
  letter-spacing: .04em;
}
.p-feature__title{
  margin: 0 0 8px;
  font-family: var(--font-jp);
  font-weight: 700;
  font-size: 16px;
  line-height: 1.55;
  color: var(--ink);
}
.p-feature__desc{
  margin: 0 0 14px;
  font-size: 12px;
  line-height: 1.85;
  color: var(--ink-2);
}
.p-feature__more{
  margin-top: auto;
  align-self: flex-start;
  display: inline-flex; align-items: center; gap: 4px;
  font-family: var(--font-jp);
  font-weight: 700;
  font-size: 12px;
  color: var(--coral);
}
.p-feature__more span{ font-size: 16px; line-height: 1 }

/* ============================================================
   Contact form
   ============================================================ */
.p-form-section{ padding: 24px 0 60px }
.p-form-section__inner{
  max-width: 760px;
  margin: 0 auto;
}
.p-form-notice{
  margin: 0 0 28px;
}
.p-form-notice ul{
  margin: 8px 0 0;
  padding-left: 1.4em;
  list-style: disc;
}
.p-form-notice ul li{ margin: .35em 0 }
.p-form-notice ul li::marker{ color: var(--coral) }
.p-form-notice a{ color: var(--coral); text-decoration: underline }

/* form */
.p-form{
  background: #fff;
  border-radius: var(--radius-lg);
  padding: 32px;
  box-shadow: var(--shadow-sm);
  border: 1px solid var(--rule);
}
.p-form__row{
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 18px;
  margin-bottom: 18px;
}
.p-form__group{ margin-bottom: 18px }
.p-form__row .p-form__group{ margin-bottom: 0 }
.p-form__label{
  display: block;
  margin-bottom: 8px;
  font-family: var(--font-jp);
  font-weight: 700;
  font-size: 13px;
  color: var(--ink);
}
.p-form__required{
  display: inline-block;
  margin-left: 6px;
  padding: 1px 8px;
  font-family: var(--font-jp);
  font-weight: 700;
  font-size: 10px;
  color: #fff;
  background: var(--coral);
  border-radius: 4px;
  vertical-align: 1px;
}
.p-form__input,
.p-form__textarea,
.p-form__select{
  width: 100%;
  padding: 11px 14px;
  background: var(--bg-soft);
  border: 1.5px solid var(--rule);
  border-radius: 10px;
  font-size: 14px;
  font-family: var(--font-jp-body);
  color: var(--ink);
  outline: none;
  transition: border-color .15s ease, background .15s ease;
}
.p-form__input:focus,
.p-form__textarea:focus,
.p-form__select:focus{
  border-color: var(--coral);
  background: #fff;
}
.p-form__textarea{
  min-height: 180px;
  resize: vertical;
  line-height: 1.85;
}
.p-form__select{
  appearance: none;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 12'><path d='M2 4l4 4 4-4' stroke='%23F08A70' stroke-width='1.8' fill='none' stroke-linecap='round' stroke-linejoin='round'/></svg>");
  background-repeat: no-repeat;
  background-position: right 14px center;
  background-size: 12px;
  padding-right: 38px;
}
.p-form__help{
  margin: 6px 0 0;
  font-size: 11px;
  color: var(--muted);
}

/* Radio (custom) */
.p-form__radio-group{
  display: flex; flex-direction: column;
  gap: 8px;
}
.p-form__radio{
  display: flex; align-items: flex-start; gap: 10px;
  padding: 10px 14px;
  background: var(--bg-soft);
  border-radius: 10px;
  cursor: pointer;
  transition: background .15s ease;
}
.p-form__radio:hover{ background: #fff }
.p-form__radio input{
  position: absolute;
  opacity: 0;
  pointer-events: none;
}
.p-form__radio-mark{
  flex-shrink: 0;
  width: 18px; height: 18px;
  border: 2px solid var(--coral-2);
  border-radius: 50%;
  background: #fff;
  margin-top: 2px;
  position: relative;
  transition: border-color .15s ease;
}
.p-form__radio input:checked + .p-form__radio-mark{
  border-color: var(--coral);
}
.p-form__radio input:checked + .p-form__radio-mark::after{
  content: "";
  position: absolute;
  inset: 3px;
  border-radius: 50%;
  background: var(--coral);
}
.p-form__radio:has(input:checked){ background: var(--coral-soft) }
.p-form__radio-text{
  font-family: var(--font-jp);
  font-weight: 500;
  font-size: 13px;
  color: var(--ink);
  line-height: 1.5;
}

/* Checkbox (custom) */
.p-form__checkbox{
  display: flex; align-items: flex-start; gap: 10px;
  cursor: pointer;
  padding: 8px 0;
}
.p-form__checkbox input{
  position: absolute;
  opacity: 0;
  pointer-events: none;
}
.p-form__checkbox-mark{
  flex-shrink: 0;
  width: 20px; height: 20px;
  border: 2px solid var(--coral-2);
  border-radius: 5px;
  background: #fff;
  margin-top: 2px;
  position: relative;
  transition: border-color .15s ease, background .15s ease;
}
.p-form__checkbox input:checked + .p-form__checkbox-mark{
  background: var(--coral);
  border-color: var(--coral);
}
.p-form__checkbox input:checked + .p-form__checkbox-mark::after{
  content: "";
  position: absolute;
  left: 5px; top: 1px;
  width: 6px; height: 11px;
  border-right: 2px solid #fff;
  border-bottom: 2px solid #fff;
  transform: rotate(45deg);
}
.p-form__checkbox-text{
  font-family: var(--font-jp);
  font-size: 12.5px;
  color: var(--ink-2);
  line-height: 1.7;
}
.p-form__checkbox-text a{ color: var(--coral); text-decoration: underline }

.p-form__actions{
  margin-top: 28px;
  text-align: center;
}
.p-form__actions .btn{ min-width: 240px; justify-content: center }
.p-form__action-note{
  margin: 10px 0 0;
  font-size: 11px;
  color: var(--muted);
}

/* Form success message */
.p-form-success{
  background: #fff;
  border-radius: var(--radius-lg);
  padding: 48px 32px;
  text-align: center;
  border: 1px solid var(--sage-soft);
  box-shadow: var(--shadow-sm);
}
.p-form-success__icon{
  margin-bottom: 18px;
}
.p-form-success__title{
  margin: 0 0 12px;
  font-family: var(--font-jp);
  font-weight: 900;
  font-size: 22px;
  color: var(--ink);
}
.p-form-success__lead{
  margin: 0 0 24px;
  font-size: 13.5px;
  line-height: 1.95;
  color: var(--ink-2);
}

/* ============================================================
   Company info section（about ページ末尾の運営者情報）
   ============================================================ */
.p-company{ padding: 24px 0 60px }
.p-company__inner{
  max-width: 760px;
  margin: 0 auto;
  background: #fff;
  border-radius: var(--radius-lg);
  padding: 28px 32px;
  box-shadow: var(--shadow-sm);
  border: 1px solid var(--rule);
}
.p-company__table{ margin: 0 }
.p-company__table a{ color: var(--coral); text-decoration: underline }

@media (max-width: 720px){
  .p-company__inner{ padding: 18px 18px }
  .p-company__table th{ width: auto; white-space: normal }
}

/* ============================================================
   Contact Form 7 — 既存 .p-form デザインに合わせる
   .p-form-cf7 ラッパ内（page-contact.php）に限定
   ============================================================ */
.p-form-cf7 .wpcf7{ margin: 0 }

/* CF7 を編集者本文と並べた時の上部余白 */
.p-form-cf7 > p:empty{ display: none }

/* フォーム本体のカード化 */
.p-form-cf7 .wpcf7-form{
  background: #fff;
  border-radius: var(--radius-lg);
  padding: 32px;
  box-shadow: var(--shadow-sm);
  border: 1px solid var(--rule);
}

/* 各項目（CF7 は <p><label> で包む構造） */
.p-form-cf7 .wpcf7-form > p{
  margin: 0 0 18px;
  display: block;
}
.p-form-cf7 .wpcf7-form > p:last-of-type{ margin-bottom: 0 }
.p-form-cf7 .wpcf7-form label{
  display: block;
  font-family: var(--font-jp);
  font-weight: 700;
  font-size: 13px;
  color: var(--ink);
  line-height: 1.7;
}
.p-form-cf7 .wpcf7-form label br{ display: block; content: ""; margin-top: 6px }
.p-form-cf7 .wpcf7-form-control-wrap{ display: block; margin-top: 8px }

/* 必須マーク（ラベル文末の「（必須）」を強調するルールはCF7では文字列のため、
   見出しに含まれる「必須」を JS なしで装飾するのは難しい。CSS では入力項目側で
   aria-required=true を視覚的に補強する方針 */
.p-form-cf7 .wpcf7-form-control[aria-required="true"]{
  /* 必須項目を coral ボーダー側で補強 */
}

/* テキスト系入力 */
.p-form-cf7 .wpcf7-form input[type="text"],
.p-form-cf7 .wpcf7-form input[type="email"],
.p-form-cf7 .wpcf7-form input[type="tel"],
.p-form-cf7 .wpcf7-form input[type="url"],
.p-form-cf7 .wpcf7-form input[type="number"],
.p-form-cf7 .wpcf7-form input[type="date"],
.p-form-cf7 .wpcf7-form textarea,
.p-form-cf7 .wpcf7-form select{
  width: 100%;
  max-width: 100%;
  padding: 11px 14px;
  background: var(--bg-soft);
  border: 1.5px solid var(--rule);
  border-radius: 10px;
  font-size: 14px;
  font-family: var(--font-jp-body);
  color: var(--ink);
  outline: none;
  transition: border-color .15s ease, background .15s ease;
  box-sizing: border-box;
}
.p-form-cf7 .wpcf7-form input[type="text"]:focus,
.p-form-cf7 .wpcf7-form input[type="email"]:focus,
.p-form-cf7 .wpcf7-form input[type="tel"]:focus,
.p-form-cf7 .wpcf7-form input[type="url"]:focus,
.p-form-cf7 .wpcf7-form input[type="number"]:focus,
.p-form-cf7 .wpcf7-form input[type="date"]:focus,
.p-form-cf7 .wpcf7-form textarea:focus,
.p-form-cf7 .wpcf7-form select:focus{
  border-color: var(--coral);
  background: #fff;
}

/* テキストエリア */
.p-form-cf7 .wpcf7-form textarea{
  min-height: 180px;
  resize: vertical;
  line-height: 1.85;
}

/* セレクト（矢印） */
.p-form-cf7 .wpcf7-form select{
  appearance: none;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 12'><path d='M2 4l4 4 4-4' stroke='%23F08A70' stroke-width='1.8' fill='none' stroke-linecap='round' stroke-linejoin='round'/></svg>");
  background-repeat: no-repeat;
  background-position: right 14px center;
  background-size: 12px;
  padding-right: 38px;
}

/* CF7 のサイズ属性（size=40 など）を無効化 */
.p-form-cf7 .wpcf7-form input[size]{ width: 100% }

/* ラジオ：横並び→縦並び＋カード型 */
.p-form-cf7 .wpcf7-radio{
  display: flex;
  flex-direction: column;
  gap: 8px;
  margin-top: 8px;
}
.p-form-cf7 .wpcf7-list-item{
  display: block;
  margin: 0;
}
.p-form-cf7 .wpcf7-radio .wpcf7-list-item label{
  display: flex;
  align-items: flex-start;
  gap: 10px;
  padding: 10px 14px;
  background: var(--bg-soft);
  border-radius: 10px;
  cursor: pointer;
  transition: background .15s ease;
  font-weight: 500;
  font-size: 13px;
}
.p-form-cf7 .wpcf7-radio .wpcf7-list-item label:hover{ background: #fff }
.p-form-cf7 .wpcf7-radio .wpcf7-list-item:has(input:checked) label{
  background: var(--coral-soft);
}
.p-form-cf7 .wpcf7-radio input[type="radio"]{
  appearance: none;
  flex-shrink: 0;
  width: 18px; height: 18px;
  border: 2px solid var(--coral-2);
  border-radius: 50%;
  background: #fff;
  margin: 2px 0 0;
  position: relative;
  cursor: pointer;
  transition: border-color .15s ease;
}
.p-form-cf7 .wpcf7-radio input[type="radio"]:checked{ border-color: var(--coral) }
.p-form-cf7 .wpcf7-radio input[type="radio"]:checked::after{
  content: "";
  position: absolute;
  inset: 3px;
  border-radius: 50%;
  background: var(--coral);
}
.p-form-cf7 .wpcf7-list-item-label{
  font-family: var(--font-jp);
  color: var(--ink);
  line-height: 1.5;
}

/* チェックボックス & 同意 (acceptance) — 共通スタイル */
.p-form-cf7 .wpcf7-checkbox,
.p-form-cf7 .wpcf7-acceptance{
  display: block;
  margin-top: 8px;
}
.p-form-cf7 .wpcf7-checkbox .wpcf7-list-item label,
.p-form-cf7 .wpcf7-acceptance .wpcf7-list-item label{
  display: flex;
  align-items: flex-start;
  gap: 10px;
  cursor: pointer;
  padding: 8px 0;
  font-weight: 500;
}
.p-form-cf7 .wpcf7-checkbox input[type="checkbox"],
.p-form-cf7 .wpcf7-acceptance input[type="checkbox"]{
  appearance: none;
  flex-shrink: 0;
  width: 20px; height: 20px;
  border: 2px solid var(--coral-2);
  border-radius: 5px;
  background: #fff;
  margin: 2px 0 0;
  position: relative;
  cursor: pointer;
  transition: border-color .15s ease, background .15s ease;
}
.p-form-cf7 .wpcf7-checkbox input[type="checkbox"]:checked,
.p-form-cf7 .wpcf7-acceptance input[type="checkbox"]:checked{
  background: var(--coral);
  border-color: var(--coral);
}
.p-form-cf7 .wpcf7-checkbox input[type="checkbox"]:checked::after,
.p-form-cf7 .wpcf7-acceptance input[type="checkbox"]:checked::after{
  content: "";
  position: absolute;
  left: 5px; top: 1px;
  width: 6px; height: 11px;
  border-right: 2px solid #fff;
  border-bottom: 2px solid #fff;
  transform: rotate(45deg);
}
.p-form-cf7 .wpcf7-checkbox .wpcf7-list-item-label,
.p-form-cf7 .wpcf7-acceptance .wpcf7-list-item-label{
  font-family: var(--font-jp);
  font-size: 12.5px;
  color: var(--ink-2);
  line-height: 1.7;
}
.p-form-cf7 .wpcf7-acceptance a{
  color: var(--coral);
  text-decoration: underline;
}

/* 送信ボタン：既存 .btn.btn-primary.btn-lg に合わせる */
.p-form-cf7 .wpcf7-submit{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  background: var(--coral);
  color: #fff;
  border: 0;
  border-radius: 999px;
  padding: 14px 32px;
  font-family: var(--font-jp);
  font-weight: 700;
  font-size: 15px;
  letter-spacing: .02em;
  cursor: pointer;
  min-width: 240px;
  box-shadow: 0 6px 16px rgba(240, 138, 112, .32);
  transition: transform .18s ease, box-shadow .18s ease, background .18s ease;
  margin-top: 12px;
}
.p-form-cf7 .wpcf7-submit:hover,
.p-form-cf7 .wpcf7-submit:focus-visible{
  background: #e87b62;
  transform: translateY(-1px);
  box-shadow: 0 8px 20px rgba(240, 138, 112, .42);
}
.p-form-cf7 .wpcf7-submit:disabled{
  opacity: .55;
  cursor: not-allowed;
  transform: none;
}
/* 送信ボタンを中央寄せにするためラップ <p> を center に */
.p-form-cf7 .wpcf7-form > p:has(.wpcf7-submit){
  text-align: center;
  margin-top: 28px;
}

/* バリデーションメッセージ */
.p-form-cf7 .wpcf7-not-valid-tip{
  display: block;
  margin-top: 6px;
  font-size: 12px;
  color: #d94e3a;
  font-weight: 600;
}
.p-form-cf7 .wpcf7-form input.wpcf7-not-valid,
.p-form-cf7 .wpcf7-form textarea.wpcf7-not-valid,
.p-form-cf7 .wpcf7-form select.wpcf7-not-valid{
  border-color: #d94e3a;
  background: #fff5f3;
}

/* レスポンス（送信後の通知） */
.p-form-cf7 .wpcf7-response-output{
  margin: 20px 0 0 !important;
  padding: 14px 18px !important;
  border-radius: 12px !important;
  border-width: 1px !important;
  font-size: 13.5px;
  line-height: 1.7;
}
.p-form-cf7 .wpcf7 form.sent .wpcf7-response-output{
  border-color: var(--sage) !important;
  background: var(--sage-soft);
  color: #2c5a51;
}
.p-form-cf7 .wpcf7 form.failed .wpcf7-response-output,
.p-form-cf7 .wpcf7 form.invalid .wpcf7-response-output,
.p-form-cf7 .wpcf7 form.unaccepted .wpcf7-response-output,
.p-form-cf7 .wpcf7 form.spam .wpcf7-response-output{
  border-color: #f0a59d !important;
  background: #fff0ec;
  color: #b53a2a;
}

/* スピナー位置調整 */
.p-form-cf7 .wpcf7-spinner{
  margin-left: 14px;
  vertical-align: middle;
}

/* ============ 編集者本文部分（CF7 と同じセクション内）============ */
/* 本文の見出し・段落も外形を整える */
.p-form-cf7 .wp-block-heading{
  margin: 28px 0 12px;
  font-family: var(--font-jp);
  font-weight: 900;
  font-size: 18px;
  color: var(--ink);
}
.p-form-cf7 .wp-block-heading:first-child{ margin-top: 0 }
.p-form-cf7 p{
  font-size: 14px;
  line-height: 1.85;
  color: var(--ink-2);
  margin: 0 0 14px;
}
.p-form-cf7 a{ color: var(--coral); text-decoration: underline }

/* レスポンシブ */
@media (max-width: 720px){
  .p-form-cf7 .wpcf7-form{ padding: 22px 18px }
  .p-form-cf7 .wpcf7-submit{ width: 100%; min-width: 0 }
}

/* ============================================================
   Legal pages (privacy / commerce)
   ============================================================ */
.p-legal{ padding: 24px 0 60px }
.p-legal__inner{
  display: grid;
  grid-template-columns: 220px 1fr;
  gap: 36px;
  align-items: flex-start;
}
.p-legal__toc{
  position: sticky;
  top: 80px;
  padding: 18px 20px;
  background: #fff;
  border-radius: var(--radius);
  border: 1px solid var(--rule);
  box-shadow: var(--shadow-sm);
}
.p-legal__toc-label{
  margin: 0 0 12px;
  font-family: var(--font-jp);
  font-weight: 700;
  font-size: 12px;
  color: var(--coral);
  letter-spacing: .04em;
}
.p-legal__toc ol{
  margin: 0;
  padding: 0;
  counter-reset: legal;
  list-style: none;
}
.p-legal__toc li{
  counter-increment: legal;
  padding: 6px 0;
  border-top: 1px dashed var(--rule);
  font-size: 12px;
}
.p-legal__toc li:first-child{ border-top: 0 }
.p-legal__toc li a::before{
  content: counter(legal) ". ";
  color: var(--coral);
  font-family: var(--font-num);
  font-weight: 700;
  margin-right: 4px;
}
.p-legal__toc a{
  color: var(--ink-2);
  font-family: var(--font-jp);
}
.p-legal__toc a:hover{ color: var(--coral) }

.p-legal__article{
  background: #fff;
  border-radius: var(--radius-lg);
  padding: 36px 40px;
  box-shadow: var(--shadow-sm);
  border: 1px solid var(--rule);
  font-size: 14px;
  line-height: 1.95;
  color: var(--ink-2);
}
.p-legal__updated{
  margin: 0 0 22px;
  padding: 6px 14px;
  display: inline-block;
  background: var(--bg-soft);
  border-radius: 999px;
  font-size: 11.5px;
  color: var(--muted);
  font-family: var(--font-num);
}
.p-legal__section{
  margin-bottom: 32px;
  scroll-margin-top: 24px;
}
.p-legal__section:last-child{ margin-bottom: 0 }
.p-legal__heading{
  margin: 0 0 14px;
  padding-left: 14px;
  border-left: 4px solid var(--coral);
  font-family: var(--font-jp);
  font-weight: 900;
  font-size: 18px;
  line-height: 1.5;
  color: var(--ink);
}
.p-legal__article p{ margin: 0 0 12px }
.p-legal__article p:last-child{ margin-bottom: 0 }
.p-legal__article ul,
.p-legal__article ol{
  margin: 0 0 14px;
  padding-left: 1.5em;
  list-style: disc;
}
.p-legal__article ul li,
.p-legal__article ol li{ margin: .3em 0 }
.p-legal__article ul li::marker{ color: var(--coral) }
.p-legal__article a{
  color: var(--coral);
  text-decoration: underline;
  text-underline-offset: 3px;
  word-break: break-all;
}
.p-legal__article strong{ font-weight: 700; color: var(--ink) }

.p-legal__table{
  width: 100%;
  border-collapse: collapse;
  margin: 0 0 16px;
  font-size: 13px;
}
.p-legal__table th,
.p-legal__table td{
  padding: 12px 16px;
  border-bottom: 1px solid var(--rule);
  text-align: left;
  vertical-align: top;
  line-height: 1.85;
}
.p-legal__table th{
  width: 220px;
  background: var(--bg-soft);
  font-family: var(--font-jp);
  font-weight: 700;
  color: var(--ink);
  white-space: nowrap;
}
.p-legal__table td{ color: var(--ink-2) }
.p-legal__table tr:last-child th,
.p-legal__table tr:last-child td{ border-bottom: 0 }
.p-legal__note{
  margin: 8px 0 0;
  font-size: 11.5px;
  color: var(--muted);
}

/* ============================================================
   Sitemap page
   ============================================================ */
.p-sitemap{ padding: 24px 0 60px }
.p-sitemap__grid{
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 24px;
}
.p-sitemap__group{
  background: #fff;
  border-radius: var(--radius);
  padding: 22px 24px;
  border: 1px solid var(--rule);
  box-shadow: var(--shadow-sm);
}
.p-sitemap__heading{
  margin: 0 0 14px;
  padding-bottom: 12px;
  border-bottom: 2px solid var(--coral-soft);
  display: flex; align-items: center; gap: 8px;
  font-family: var(--font-jp);
  font-weight: 900;
  font-size: 16px;
  color: var(--ink);
}
.p-sitemap__list{
  margin: 0;
  padding: 0;
  list-style: none;
}
.p-sitemap__list li{
  display: flex; flex-wrap: wrap;
  align-items: baseline;
  gap: 4px 12px;
  padding: 9px 0;
  border-top: 1px dashed var(--rule);
  font-family: var(--font-jp);
}
.p-sitemap__list li:first-child{ border-top: 0 }
.p-sitemap__list a{
  font-weight: 700;
  font-size: 13.5px;
  color: var(--ink);
  position: relative;
  padding-left: 14px;
  flex: 0 1 auto;
}
.p-sitemap__list a::before{
  content: "›";
  position: absolute;
  left: 0;
  color: var(--coral);
  font-weight: 700;
}
.p-sitemap__list a:hover{ color: var(--coral) }
.p-sitemap__list span{
  font-size: 11.5px;
  color: var(--muted);
  flex: 1 1 auto;
}
.p-sitemap__note{
  margin-top: 24px;
  padding: 14px 18px;
  background: var(--sage-soft);
  border-radius: var(--radius);
  font-size: 12px;
  color: var(--ink-2);
  line-height: 1.85;
}
.p-sitemap__note p{ margin: 0 }
.p-sitemap__note a{
  color: var(--coral);
  text-decoration: underline;
}

/* ============================================================
   Responsive — Feature / Contact / Legal / Sitemap
   ============================================================ */
@media (max-width: 1080px){
  .p-feature__grid{ grid-template-columns: repeat(2, 1fr) }
  .p-legal__inner{ grid-template-columns: 200px 1fr; gap: 24px }
}

@media (max-width: 920px){
  .p-feature-pickup__card{ grid-template-columns: 1fr }
  .p-feature-pickup__media{ min-height: 240px; aspect-ratio: 16/9 }
  .p-feature-pickup__body{ padding: 26px 24px }
  .p-feature-pickup__title{ font-size: 22px }

  .p-feature__grid{ grid-template-columns: repeat(2, 1fr); gap: 16px }

  .p-legal__inner{ grid-template-columns: 1fr }
  .p-legal__toc{
    position: static;
    margin-bottom: 0;
  }
  .p-legal__article{ padding: 28px 26px }

  .p-sitemap__grid{ grid-template-columns: 1fr; gap: 18px }
}

@media (max-width: 720px){
  .p-feature-pickup__body{ padding: 22px 20px }
  .p-feature-pickup__title{ font-size: 19px }
  .p-feature__grid{ grid-template-columns: 1fr; gap: 16px }

  .p-form{ padding: 24px 20px }
  .p-form__row{ grid-template-columns: 1fr; gap: 0 }
  .p-form__row .p-form__group{ margin-bottom: 18px }
  .p-form__actions .btn{ min-width: 0; width: 100% }

  .p-form-success{ padding: 32px 20px }
  .p-form-success__title{ font-size: 18px }

  .p-legal__article{ padding: 22px 20px; font-size: 13.5px }
  .p-legal__heading{ font-size: 16px }
  .p-legal__table th{ width: auto }
  .p-legal__table th,
  .p-legal__table td{
    display: block;
    padding: 8px 12px;
    border-bottom: 0;
  }
  .p-legal__table tr{
    display: block;
    border-bottom: 1px solid var(--rule);
    padding: 8px 0;
  }
  .p-legal__table tr:last-child{ border-bottom: 0 }
  .p-legal__table th{ background: transparent; padding-bottom: 2px; font-size: 11.5px; color: var(--coral) }

  .p-sitemap__group{ padding: 18px 20px }
  .p-sitemap__heading{ font-size: 15px }
  .p-sitemap__list li{ gap: 2px 10px }
  .p-sitemap__list span{ flex: 1 1 100% }
}

@media (max-width: 480px){
  .p-feature-pickup__title{ font-size: 17px }
  .p-feature__title{ font-size: 15px }
}

/* Fix: legal page <ol> should be decimal, nested lists keep proper styling */
.p-legal__article ol{ list-style: decimal }
.p-legal__article ol ol{ list-style: lower-alpha; padding-left: 1.4em; margin-top: 6px }
.p-legal__article ol ul{ list-style: disc; padding-left: 1.4em; margin-top: 6px }
.p-legal__article ol li{ margin: .4em 0 }

/* ============================================================
   Page hero — additional modifiers
   ============================================================ */
.p-page-hero--press{ background: linear-gradient(180deg, #F0E5D6 0%, var(--bg) 100%) }
.p-page-hero--ad{ background: linear-gradient(180deg, var(--yellow-soft) 0%, var(--bg) 100%) }

/* ============================================================
   Press page
   ============================================================ */
.p-press{ padding: 24px 0 60px }

.p-press__grid{
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 18px;
  margin-bottom: 50px;
}
.p-press__card{
  padding: 24px;
  background: #fff;
  border-radius: var(--radius);
  border: 1px solid var(--rule);
  box-shadow: var(--shadow-sm);
}
.p-press__icon{
  width: 48px; height: 48px;
  margin-bottom: 14px;
  background: var(--bg-soft);
  border-radius: 12px;
  display: grid; place-items: center;
}
.p-press__heading{
  margin: 0 0 8px;
  font-family: var(--font-jp);
  font-weight: 700;
  font-size: 16px;
  color: var(--ink);
  line-height: 1.55;
}
.p-press__body{
  margin: 0;
  font-size: 12.5px;
  line-height: 1.9;
  color: var(--ink-2);
}
.p-press__body a{
  color: var(--coral);
  text-decoration: underline;
}

.p-press__info{
  max-width: 760px;
  margin: 0 auto 50px;
}

.p-press__contact{
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 18px;
  margin: 0 0 50px;
}
.p-press__contact-card{
  padding: 26px 28px;
  border-radius: var(--radius);
  background: linear-gradient(180deg, #FFF6EE 0%, #fff 100%);
  border: 1px solid var(--rule);
  box-shadow: var(--shadow-sm);
}
.p-press__contact-card--alt{
  background: linear-gradient(180deg, var(--sage-soft) 0%, #fff 100%);
}
.p-press__contact-label{
  display: inline-block;
  margin: 0 0 10px;
  padding: 3px 12px;
  background: #fff;
  color: var(--coral);
  border-radius: 999px;
  font-family: var(--font-num);
  font-weight: 700;
  font-size: 10.5px;
  letter-spacing: .1em;
}
.p-press__contact-card--alt .p-press__contact-label{ color: #3f7e8b }
.p-press__contact-title{
  margin: 0 0 10px;
  font-family: var(--font-jp);
  font-weight: 700;
  font-size: 16px;
  color: var(--ink);
}
.p-press__contact-body{
  margin: 0 0 14px;
  font-size: 12.5px;
  line-height: 1.85;
  color: var(--ink-2);
}
.p-press__contact-mail{
  margin: 0 0 14px;
  padding: 10px 14px;
  background: #fff;
  border-radius: 8px;
  border: 1px solid var(--rule);
  font-family: var(--font-num);
  font-weight: 700;
  font-size: 14px;
  color: var(--ink);
  text-align: center;
  letter-spacing: .02em;
}

.p-press__mentions{
  max-width: 760px;
  margin: 0 auto;
  padding: 22px 26px;
  background: #fff;
  border-radius: var(--radius);
  border: 1px solid var(--rule);
  list-style: none;
}
.p-press__mentions li{
  padding: 10px 0;
  border-top: 1px dashed var(--rule);
  font-size: 12.5px;
  color: var(--ink-2);
}
.p-press__mentions li:first-child{ border-top: 0 }

/* ============================================================
   Ad rate page
   ============================================================ */
.p-ad-rate__stats-section{ padding: 30px 0 50px }
.p-ad-rate__stats{
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 16px;
  margin-top: 24px;
}
.p-ad-rate__stat{
  background: #fff;
  border-radius: var(--radius);
  padding: 22px 16px;
  text-align: center;
  border: 1px solid var(--rule);
  box-shadow: var(--shadow-sm);
}
.p-ad-rate__stat-num{
  margin: 0 0 4px;
  font-family: var(--font-num);
  font-weight: 700;
  font-size: 26px;
  color: var(--coral);
  line-height: 1.2;
}
.p-ad-rate__stat-label{
  margin: 0;
  font-size: 11.5px;
  color: var(--ink-2);
  font-family: var(--font-jp);
}
.p-ad-rate__stats-note{
  margin: 14px 0 0;
  text-align: center;
  font-size: 11px;
  color: var(--muted);
}

/* Audience */
.p-ad-rate__audience{ padding: 30px 0 50px; background: var(--bg-soft) }
.p-ad-rate__audience-grid{
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 16px;
  margin-top: 24px;
}
.p-ad-rate__audience-card{
  background: #fff;
  border-radius: var(--radius);
  padding: 22px 18px;
  text-align: center;
  border: 1px solid var(--rule);
}
.p-ad-rate__audience-label{
  margin: 0 0 6px;
  font-size: 11px;
  color: var(--coral);
  font-family: var(--font-jp);
  font-weight: 700;
  letter-spacing: .04em;
}
.p-ad-rate__audience-main{
  margin: 0 0 4px;
  font-family: var(--font-jp);
  font-weight: 700;
  font-size: 16px;
  color: var(--ink);
}
.p-ad-rate__audience-sub{
  margin: 0;
  font-size: 11px;
  color: var(--muted);
}

/* Plans */
.p-ad-rate__plans-section{ padding: 30px 0 50px }
.p-ad-rate__plans{
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 20px;
  margin-top: 24px;
}
.p-ad-rate__plan{
  position: relative;
  background: #fff;
  border-radius: var(--radius);
  padding: 28px 26px;
  border: 1px solid var(--rule);
  box-shadow: var(--shadow-sm);
}
.p-ad-rate__plan--featured{
  border-color: var(--coral);
  background: linear-gradient(180deg, var(--coral-soft) 0%, #fff 30%);
}
.p-ad-rate__plan-no{
  display: inline-block;
  margin-bottom: 10px;
  font-family: var(--font-num);
  font-weight: 700;
  font-size: 14px;
  color: var(--coral);
  letter-spacing: .12em;
}
.p-ad-rate__plan-badge{
  position: absolute;
  top: 18px; right: 18px;
  padding: 4px 12px;
  background: var(--coral);
  color: #fff;
  border-radius: 999px;
  font-family: var(--font-jp);
  font-weight: 700;
  font-size: 10.5px;
}
.p-ad-rate__plan-name{
  margin: 0 0 10px;
  font-family: var(--font-jp);
  font-weight: 900;
  font-size: 19px;
  color: var(--ink);
  line-height: 1.5;
}
.p-ad-rate__plan-desc{
  margin: 0 0 14px;
  font-size: 12.5px;
  line-height: 1.9;
  color: var(--ink-2);
}
.p-ad-rate__plan-spec{
  margin: 0 0 16px;
  padding: 14px 16px;
  background: var(--bg-soft);
  border-radius: 10px;
  font-size: 12px;
  list-style: none;
}
.p-ad-rate__plan--featured .p-ad-rate__plan-spec{ background: rgba(255,255,255,.6) }
.p-ad-rate__plan-spec li{
  padding: 4px 0 4px 18px;
  position: relative;
  color: var(--ink-2);
  line-height: 1.6;
}
.p-ad-rate__plan-spec li::before{
  content: "✓";
  position: absolute;
  left: 0;
  color: var(--coral);
  font-weight: 700;
}
.p-ad-rate__plan-price{
  margin: 0;
  font-family: var(--font-num);
  font-weight: 700;
  font-size: 18px;
  color: var(--ink);
}

/* Flow */
.p-ad-rate__flow-section{ padding: 30px 0 50px; background: var(--bg-soft) }
.p-ad-rate__flow{
  list-style: none;
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 12px;
  margin-top: 24px;
  padding: 0;
}
.p-ad-rate__flow-step{
  background: #fff;
  border-radius: var(--radius);
  padding: 22px 18px;
  text-align: center;
  border: 1px solid var(--rule);
  position: relative;
}
.p-ad-rate__flow-step + .p-ad-rate__flow-step::before{
  content: "›";
  position: absolute;
  left: -10px; top: 50%;
  transform: translateY(-50%);
  font-size: 22px;
  color: var(--coral);
  font-weight: 700;
}
.p-ad-rate__flow-step span{
  display: inline-grid; place-items: center;
  width: 32px; height: 32px;
  border-radius: 50%;
  background: var(--coral);
  color: #fff;
  font-family: var(--font-num);
  font-weight: 700;
  font-size: 14px;
  margin-bottom: 10px;
}
.p-ad-rate__flow-step h3{
  margin: 0 0 6px;
  font-family: var(--font-jp);
  font-weight: 700;
  font-size: 13.5px;
  color: var(--ink);
  line-height: 1.4;
}
.p-ad-rate__flow-step p{
  margin: 0;
  font-size: 11px;
  line-height: 1.7;
  color: var(--ink-2);
}

/* Policy callout wrapper */
.p-ad-rate__policy{ padding: 24px 0 0 }
.p-ad-rate__policy ul{
  margin: 8px 0 0;
  padding-left: 1.4em;
  list-style: disc;
}
.p-ad-rate__policy ul li{ margin: .35em 0; line-height: 1.85 }
.p-ad-rate__policy ul li::marker{ color: var(--coral) }

/* ============================================================
   Newsletter LP
   ============================================================ */
.p-nl-lp__hero{
  position: relative;
  padding: 56px 0 64px;
  background: linear-gradient(135deg, var(--coral-soft) 0%, var(--yellow-soft) 100%);
  overflow: hidden;
}
.p-nl-lp__hero-inner{
  position: relative;
  display: grid;
  grid-template-columns: 1.1fr 1fr;
  gap: 40px;
  align-items: center;
}
.p-nl-lp__hero-deco{
  position: absolute;
  pointer-events: none;
  z-index: 1;
}
.p-nl-lp__hero-deco--1{ width: 110px; left: -10px; top: -10px; opacity: .55; transform: rotate(-8deg) }
.p-nl-lp__hero-deco--2{ width: 70px; right: 8%; top: 12%; opacity: .65 }
.p-nl-lp__hero-deco--3{ width: 60px; left: 30%; bottom: 0; opacity: .55 }

.p-nl-lp__hero-text{ position: relative; z-index: 2 }
.p-nl-lp__badge{
  display: inline-block;
  margin: 0 0 16px;
  padding: 5px 14px;
  background: #fff;
  color: var(--coral);
  border-radius: 999px;
  font-family: var(--font-num);
  font-weight: 700;
  font-size: 11.5px;
  letter-spacing: .1em;
  box-shadow: var(--shadow-sm);
}
.p-nl-lp__title{
  margin: 0 0 18px;
  font-family: var(--font-jp);
  font-weight: 900;
  font-size: 38px;
  line-height: 1.5;
  color: var(--ink);
  letter-spacing: .005em;
}
.p-nl-lp__title-em{ color: var(--coral) }
.p-nl-lp__lead{
  margin: 0 0 20px;
  font-size: 14px;
  line-height: 2;
  color: var(--ink-2);
}
.p-nl-lp__bullets{
  margin: 0;
  padding: 0;
  list-style: none;
}
.p-nl-lp__bullets li{
  position: relative;
  padding: 6px 0 6px 26px;
  font-size: 13px;
  line-height: 1.85;
  color: var(--ink);
  font-family: var(--font-jp);
  font-weight: 500;
}
.p-nl-lp__bullets li::before{
  content: "✓";
  position: absolute;
  left: 0; top: 6px;
  width: 18px; height: 18px;
  background: var(--coral);
  color: #fff;
  border-radius: 50%;
  font-size: 11px;
  font-weight: 700;
  display: grid; place-items: center;
}

.p-nl-lp__form{
  position: relative;
  z-index: 2;
  background: #fff;
  border-radius: var(--radius-lg);
  padding: 28px 26px;
  box-shadow: var(--shadow-md);
  border: 1px solid var(--rule);
}
.p-nl-lp__form-title{
  margin: 0 0 4px;
  font-family: var(--font-jp);
  font-weight: 900;
  font-size: 17px;
  color: var(--ink);
}
.p-nl-lp__form-sub{
  margin: 0 0 18px;
  font-size: 11.5px;
  color: var(--muted);
}
.p-nl-lp__form-label{
  display: block;
  margin-bottom: 6px;
  font-family: var(--font-jp);
  font-weight: 700;
  font-size: 12px;
  color: var(--ink);
}
.p-nl-lp__form-input{
  width: 100%;
  padding: 13px 16px;
  background: var(--bg-soft);
  border: 1.5px solid var(--rule);
  border-radius: 10px;
  font-size: 14px;
  font-family: var(--font-num);
  color: var(--ink);
  outline: none;
  margin-bottom: 14px;
  transition: border-color .15s ease, background .15s ease;
}
.p-nl-lp__form-input:focus{
  border-color: var(--coral);
  background: #fff;
}
.p-nl-lp__form-radio{
  display: flex; align-items: center; gap: 10px;
  padding: 8px 12px;
  border-radius: 8px;
  cursor: pointer;
  margin-bottom: 6px;
  transition: background .15s ease;
}
.p-nl-lp__form-radio:hover{ background: var(--bg-soft) }
.p-nl-lp__form-radio input{
  position: absolute;
  opacity: 0;
  pointer-events: none;
}
.p-nl-lp__form-radio:has(input:checked){ background: var(--coral-soft) }
.p-nl-lp__form-radio .p-form__radio-text{ font-size: 12.5px }
.p-nl-lp__form-submit{
  display: block;
  width: 100%;
  margin-top: 18px;
  padding: 14px 28px !important;
  font-size: 15px !important;
  justify-content: center;
}
.p-nl-lp__form-note{
  margin: 12px 0 0;
  text-align: center;
  font-size: 11px;
  color: var(--muted);
}
.p-nl-lp__success{ margin-top: 30px }

/* Benefits */
.p-nl-lp__benefits{ padding: 60px 0 50px }
.p-nl-lp__benefits-grid{
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 22px;
}
.p-nl-lp__benefit{
  position: relative;
  padding: 28px 26px;
  background: #fff;
  border-radius: var(--radius-lg);
  border: 1px solid var(--rule);
  box-shadow: var(--shadow-sm);
}
.p-nl-lp__benefit-icon{
  width: 56px; height: 56px;
  margin-bottom: 14px;
  background: var(--bg-soft);
  border-radius: 16px;
  display: grid; place-items: center;
}
.p-nl-lp__benefit-title{
  margin: 0 0 10px;
  font-family: var(--font-jp);
  font-weight: 700;
  font-size: 16px;
  color: var(--ink);
  line-height: 1.55;
}
.p-nl-lp__benefit-body{
  margin: 0;
  font-size: 12.5px;
  line-height: 1.95;
  color: var(--ink-2);
}

/* Past samples */
.p-nl-lp__samples{ padding: 50px 0; background: var(--bg-soft) }
.p-nl-lp__samples-grid{
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 18px;
}
.p-nl-lp__sample{
  background: #fff;
  border-radius: var(--radius);
  padding: 22px 22px;
  border: 1px solid var(--rule);
}
.p-nl-lp__sample-no{
  display: inline-block;
  margin: 0 0 4px;
  font-family: var(--font-num);
  font-weight: 700;
  font-size: 11px;
  color: var(--coral);
  letter-spacing: .14em;
}
.p-nl-lp__sample-date{
  margin: 0 0 10px;
  font-family: var(--font-num);
  font-size: 11px;
  color: var(--muted);
}
.p-nl-lp__sample-title{
  margin: 0 0 10px;
  font-family: var(--font-jp);
  font-weight: 700;
  font-size: 14.5px;
  color: var(--ink);
  line-height: 1.55;
}
.p-nl-lp__sample-body{
  margin: 0;
  font-size: 12px;
  line-height: 1.9;
  color: var(--ink-2);
}

/* FAQ wrapper for LP */
.p-nl-lp__faq{ padding: 50px 0 }

/* Trust */
.p-nl-lp__trust{ padding: 30px 0 60px }
.p-nl-lp__trust-grid{
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
}
.p-nl-lp__trust-item{
  padding: 22px;
  background: #fff;
  border-radius: var(--radius);
  border: 1px solid var(--rule);
  display: flex; align-items: center; gap: 14px;
}
.p-nl-lp__trust-item p{
  margin: 0;
  font-family: var(--font-jp);
  font-weight: 700;
  font-size: 12.5px;
  line-height: 1.6;
  color: var(--ink);
}

/* ============================================================
   404 page
   ============================================================ */
.p-404{
  position: relative;
  padding: 60px 0 70px;
  text-align: center;
  overflow: hidden;
}
.p-404__inner{ position: relative }
.p-404__deco{
  position: absolute;
  pointer-events: none;
  z-index: 0;
}
.p-404__deco--1{ width: 90px; left: 8%; top: 0; opacity: .5; transform: rotate(-12deg) }
.p-404__deco--2{ width: 60px; right: 10%; top: 8%; opacity: .65 }
.p-404__deco--3{ width: 80px; right: 15%; bottom: 50px; opacity: .5 }

.p-404__num{
  position: relative;
  z-index: 1;
  margin: 0;
  font-family: var(--font-num);
  font-weight: 700;
  font-size: 120px;
  line-height: 1;
  color: var(--coral);
  letter-spacing: -.02em;
  text-shadow: 0 6px 0 rgba(240,138,112,.18);
}
.p-404__paw{
  position: relative;
  z-index: 1;
  margin: 8px auto 14px;
  display: block;
  transform: rotate(8deg);
}
.p-404__title{
  position: relative;
  z-index: 1;
  margin: 0 0 14px;
  font-family: var(--font-jp);
  font-weight: 900;
  font-size: 26px;
  color: var(--ink);
}
.p-404__lead{
  position: relative;
  z-index: 1;
  max-width: 540px;
  margin: 0 auto 30px;
  font-size: 13.5px;
  line-height: 2;
  color: var(--ink-2);
}

/* Search */
.p-404__search{
  position: relative;
  z-index: 1;
  max-width: 520px;
  margin: 0 auto 26px;
}
.p-404__search-label{
  display: block;
  margin-bottom: 8px;
  font-family: var(--font-jp);
  font-weight: 700;
  font-size: 12px;
  color: var(--ink-2);
}
.p-404__search-row{
  display: flex; gap: 8px;
  background: #fff;
  border: 1.5px solid var(--rule);
  border-radius: 999px;
  padding: 4px 4px 4px 18px;
  align-items: center;
  box-shadow: var(--shadow-sm);
  transition: border-color .15s ease;
}
.p-404__search-row:focus-within{ border-color: var(--coral) }
.p-404__search-input{
  flex: 1;
  border: 0;
  outline: none;
  background: transparent;
  font-size: 14px;
  font-family: var(--font-jp-body);
  color: var(--ink);
  padding: 6px 0;
}
.p-404__search .btn{ flex-shrink: 0 }

/* Quick links */
.p-404__links{
  position: relative;
  z-index: 1;
  margin: 0 auto 40px;
}
.p-404__links-label{
  margin: 0 0 12px;
  font-family: var(--font-jp);
  font-weight: 700;
  font-size: 12px;
  color: var(--muted);
}
.p-404__links-row{
  display: flex; flex-wrap: wrap; justify-content: center;
  gap: 8px;
}

/* Suggested articles */
.p-404__suggestions{
  position: relative;
  z-index: 1;
  text-align: left;
  margin-top: 30px;
}
.p-404__suggestions-title{
  margin: 0 0 18px;
  font-family: var(--font-jp);
  font-weight: 900;
  font-size: 18px;
  display: inline-flex; align-items: center; gap: 8px;
  color: var(--ink);
}

/* ============================================================
   Responsive — Press / Ad / NL-LP / 404
   ============================================================ */
@media (max-width: 1080px){
  .p-ad-rate__stats{ grid-template-columns: repeat(3, 1fr) }
  .p-ad-rate__audience-grid{ grid-template-columns: repeat(2, 1fr) }
  .p-ad-rate__flow{ grid-template-columns: repeat(2, 1fr) }
  .p-ad-rate__flow-step + .p-ad-rate__flow-step::before{ display: none }

  .p-nl-lp__benefits-grid{ grid-template-columns: 1fr; gap: 14px }
  .p-nl-lp__samples-grid{ grid-template-columns: repeat(2, 1fr) }
}

@media (max-width: 920px){
  .p-press__grid{ grid-template-columns: 1fr; gap: 14px }
  .p-press__contact{ grid-template-columns: 1fr; gap: 14px }

  .p-ad-rate__stats{ grid-template-columns: repeat(2, 1fr) }
  .p-ad-rate__plans{ grid-template-columns: 1fr; gap: 14px }

  .p-nl-lp__hero{ padding: 40px 0 50px }
  .p-nl-lp__hero-inner{ grid-template-columns: 1fr; gap: 30px }
  .p-nl-lp__title{ font-size: 30px }
  .p-nl-lp__hero-deco--1{ width: 70px; opacity: .35 }
  .p-nl-lp__hero-deco--2{ width: 50px }
  .p-nl-lp__samples-grid{ grid-template-columns: 1fr; gap: 14px }
  .p-nl-lp__trust-grid{ grid-template-columns: 1fr; gap: 12px }

  .p-404__num{ font-size: 96px }
}

@media (max-width: 720px){
  .p-press__card{ padding: 18px }
  .p-press__contact-card{ padding: 22px 20px }

  .p-ad-rate__stats{ grid-template-columns: 1fr 1fr; gap: 10px }
  .p-ad-rate__stat{ padding: 18px 12px }
  .p-ad-rate__stat-num{ font-size: 22px }
  .p-ad-rate__audience-grid{ grid-template-columns: 1fr; gap: 12px }
  .p-ad-rate__flow{ grid-template-columns: 1fr }
  .p-ad-rate__plan{ padding: 22px 20px }
  .p-ad-rate__plan-name{ font-size: 17px }

  .p-nl-lp__title{ font-size: 24px; line-height: 1.5 }
  .p-nl-lp__form{ padding: 22px 20px }

  .p-404__num{ font-size: 72px }
  .p-404__title{ font-size: 21px }
  .p-404__lead{ font-size: 13px }
  .p-404__search-row{ padding: 4px 4px 4px 14px }
  .p-404__deco{ display: none }
}

@media (max-width: 480px){
  .p-press__contact-mail{ font-size: 12px }

  .p-ad-rate__plan-badge{ position: static; display: inline-block; margin-bottom: 10px }

  .p-nl-lp__title{ font-size: 21px }
  .p-nl-lp__form-title{ font-size: 15px }
}

/* ============================================================
   モバイルドロワーメニュー
   ============================================================ */

/* ハンバーガートグル（desktop非表示／mobileのみ表示） */
.menu-toggle{
  display: none;
  width: 36px; height: 36px;
  border-radius: 50%;
  align-items: center;
  justify-content: center;
  background: transparent;
  border: 0;
  cursor: pointer;
  flex-shrink: 0;
  transition: background .2s ease;
}
.menu-toggle:hover{ background: #fff }
.menu-toggle:focus-visible{ outline: 2px solid var(--coral); outline-offset: 2px }

.menu-toggle__bars{
  display: flex;
  flex-direction: column;
  gap: 4px;
  width: 18px;
}
.menu-toggle__bars span{
  display: block;
  width: 100%;
  height: 2px;
  background: var(--ink);
  border-radius: 2px;
  transition: transform .25s ease, opacity .2s ease;
  transform-origin: center;
}
.menu-toggle[aria-expanded="true"] .menu-toggle__bars span:nth-child(1){
  transform: translateY(6px) rotate(45deg);
}
.menu-toggle[aria-expanded="true"] .menu-toggle__bars span:nth-child(2){
  opacity: 0;
}
.menu-toggle[aria-expanded="true"] .menu-toggle__bars span:nth-child(3){
  transform: translateY(-6px) rotate(-45deg);
}

@media (max-width: 920px){
  .menu-toggle{ display: inline-flex }
}

/* ドロワー本体 */
.drawer{
  position: fixed;
  inset: 0;
  z-index: 100;
  visibility: hidden;
  pointer-events: none;
}
.drawer.is-open{
  visibility: visible;
  pointer-events: auto;
}

.drawer__overlay{
  position: absolute;
  inset: 0;
  background: rgba(94, 68, 51, .42);
  opacity: 0;
  transition: opacity .25s ease;
  cursor: pointer;
}
.drawer.is-open .drawer__overlay{ opacity: 1 }

.drawer__panel{
  position: absolute;
  top: 0; right: 0; bottom: 0;
  width: 84%;
  max-width: 360px;
  background: var(--bg);
  display: flex;
  flex-direction: column;
  box-shadow: -8px 0 32px rgba(94, 68, 51, .15);
  transform: translateX(100%);
  transition: transform .3s cubic-bezier(.2, .8, .2, 1);
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
}
.drawer.is-open .drawer__panel{ transform: translateX(0) }

/* ドロワーヘッダー */
.drawer__head{
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 16px 20px;
  border-bottom: 1px solid var(--rule);
  flex-shrink: 0;
}
.drawer__head .brand{
  display: flex;
  align-items: center;
  gap: 10px;
  flex: 1;
  min-width: 0;
}
.drawer__head .brand-mark{ width: 38px; height: 38px }
.drawer__head .brand-name{ font-size: 14px; font-family: var(--font-jp); font-weight: 700 }
.drawer__head .brand-tag{ font-size: 10px; color: var(--muted) }

.drawer__close{
  width: 36px; height: 36px;
  border-radius: 50%;
  background: #fff;
  border: 1px solid var(--rule);
  display: grid;
  place-items: center;
  cursor: pointer;
  flex-shrink: 0;
  transition: background .15s ease, border-color .15s ease;
}
.drawer__close:hover{
  background: var(--coral-soft);
  border-color: var(--coral);
}
.drawer__close:hover svg path{ stroke: var(--coral) }

/* ドロワーナビゲーション */
.drawer__nav{
  display: flex;
  flex-direction: column;
  padding: 8px 20px 14px;
}
.drawer__nav-link{
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 16px 4px;
  border-bottom: 1px dashed var(--rule);
  font-family: var(--font-jp);
  font-weight: 500;
  font-size: 15px;
  color: var(--ink);
  text-decoration: none;
  transition: color .15s ease, padding-left .15s ease;
}
.drawer__nav-link:hover,
.drawer__nav-link:focus-visible{
  color: var(--coral);
  padding-left: 8px;
}
.drawer__nav-link::after{
  content: "›";
  color: var(--coral);
  font-size: 18px;
  font-weight: 700;
  line-height: 1;
}
.drawer__nav-link.is-active{
  color: var(--coral);
  font-weight: 700;
}

/* カテゴリーリンクの下に展開するサブリスト（小さめフォント） */
.drawer__nav-sublist{
  display: flex;
  flex-direction: column;
  padding: 6px 0 10px 14px;
  margin: -2px 0 0;
  border-bottom: 1px dashed var(--rule);
  background: var(--bg-soft);
  border-radius: 10px;
}
.drawer__nav-sublink{
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 8px 10px;
  font-family: var(--font-jp);
  font-size: 12.5px;
  font-weight: 500;
  color: var(--ink-2);
  text-decoration: none;
  border-radius: 8px;
  transition: color .15s ease, background .15s ease;
}
.drawer__nav-sublink:hover,
.drawer__nav-sublink:focus-visible{
  color: var(--coral);
  background: #fff;
}
.drawer__nav-sublink.is-active{
  color: var(--coral);
  font-weight: 700;
}
.drawer__nav-sublink-dot{
  flex: 0 0 auto;
  width: 6px; height: 6px; border-radius: 50%;
  background: var(--coral-2);
}
.drawer__nav-sublink.cat-training .drawer__nav-sublink-dot{ background: #7FB8AB }
.drawer__nav-sublink.cat-cat-life .drawer__nav-sublink-dot{ background: #C49BD9 }
.drawer__nav-sublink.cat-food .drawer__nav-sublink-dot{ background: #F08A70 }
.drawer__nav-sublink.cat-health .drawer__nav-sublink-dot{ background: #6FB1E0 }
.drawer__nav-sublink.cat-trip .drawer__nav-sublink-dot{ background: #F5C26B }
.drawer__nav-sublink.cat-goods .drawer__nav-sublink-dot{ background: #B7CF7A }
.drawer__nav-sublink-count{
  margin-left: auto;
  font-family: var(--font-num);
  font-size: 10.5px;
  color: var(--muted);
  background: #fff;
  padding: 1px 7px;
  border-radius: 999px;
}

/* ドロワー検索 */
.drawer__search{
  margin: 14px 20px 0;
  display: flex;
  align-items: center;
  background: #fff;
  border: 1px solid var(--rule);
  border-radius: 999px;
  overflow: hidden;
  box-shadow: var(--shadow-sm);
}
.drawer__search input{
  flex: 1;
  border: 0;
  outline: none;
  padding: 11px 16px;
  font-size: 13px;
  background: transparent;
  color: var(--ink);
  min-width: 0;
}
.drawer__search input::placeholder{ color: var(--muted) }
.drawer__search button{
  background: var(--coral);
  width: 38px; height: 38px;
  display: grid;
  place-items: center;
  border: 0;
  border-radius: 50%;
  margin: 2px;
  cursor: pointer;
  flex-shrink: 0;
}

/* ドロワーフッター */
.drawer__footer{
  margin-top: auto;
  padding: 22px 20px;
  border-top: 1px solid var(--rule);
}
.drawer__cta{
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  background: var(--coral);
  color: #fff !important;
  padding: 13px 18px;
  border-radius: 999px;
  font-family: var(--font-jp);
  font-weight: 700;
  font-size: 14px;
  text-decoration: none !important;
  box-shadow: 0 4px 12px rgba(240, 138, 112, .3);
  transition: background .2s ease;
}
.drawer__cta:hover{ background: #e87b62 }

.drawer__sub-links{
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 14px;
  margin-top: 16px;
}
.drawer__sub-links a{
  font-size: 11.5px;
  color: var(--muted);
  text-decoration: none;
}
.drawer__sub-links a:hover{ color: var(--coral) }

/* ドロワー開放時の本文スクロールロック */
body.is-drawer-open{
  overflow: hidden;
  position: fixed;
  width: 100%;
}

/* prefers-reduced-motion 対応 */
@media (prefers-reduced-motion: reduce){
  .drawer__panel,
  .drawer__overlay,
  .menu-toggle__bars span{
    transition: none;
  }
}

/* ============================================================
   WordPress標準ページネーションクラスのサポート
   paginate_links() の出力（.page-numbers 等）を c-pagination 風にスタイル
   ============================================================ */
.c-pagination__list .page-numbers,
.c-pagination__list a.page-numbers{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 36px;
  height: 36px;
  padding: 0 10px;
  border-radius: 999px;
  background: var(--bg-soft);
  font-family: var(--font-num);
  font-weight: 700;
  font-size: 13px;
  color: var(--ink-2);
  text-decoration: none !important;
  border: 1px solid transparent;
  transition: background .2s ease, color .2s ease;
}
.c-pagination__list a.page-numbers:hover{
  background: var(--coral-soft);
  color: var(--coral);
}
.c-pagination__list .page-numbers.current{
  background: var(--coral);
  color: #fff;
}
.c-pagination__list .page-numbers.dots{
  background: transparent;
  color: var(--muted);
  min-width: 24px;
  padding: 0;
}

@media (max-width: 720px){
  .c-pagination__list .page-numbers,
  .c-pagination__list a.page-numbers{
    min-width: 32px; height: 32px; font-size: 12px;
  }
}

/* ============================================================
   Utilities — レスポンシブ表示切替
   ============================================================ */
/* PC（>920px）でのみ表示。モバイル/タブレットでは非表示。
   <br class="u-pc-only" /> として改行制御に使うのが主な用途。 */
.u-pc-only{ display: none !important }
@media (min-width: 921px){
  .u-pc-only{ display: revert !important }
}
