/* === Base ===
 * html はグローバル適用。タイポグラフィ（font-family / color / line-height /
 * overflow-x）はブランド共通として全ページに当てる。背景・isolation・
 * font-size は新デザイン専用なので .is-look-redesign スコープに限定する。 */
html { overflow-x: clip; }
body {
  font-family: var(--font-base);
  color: var(--color-text);
  line-height: var(--lh-base);
  overflow-x: clip;    /* 透かしの横はみ出しを抑制（スティッキーには影響しない）*/
}
.is-look-redesign {
  font-size: var(--fs-md);
  position: relative;
  isolation: isolate;  /* bodyに stacking context を作る（page-bg の z-index:-1 を内側で有効化）*/
}

/* === Cocoon ページ（固定ページ・通常投稿）の背景 ===
 * 固定ページは本文長が可変で .page-bg--* の固定高さと合わずクリームが
 * 中途で切れるため、body 全体をクリームで塗りつぶし、曲線 SVG は非表示にする。
 * .is-look-redesign が付かない = look_is_redesign_page() が false の全ページが対象。 */
body:not(.is-look-redesign) {
  background: var(--color-bg-cream);
}
body:not(.is-look-redesign) .page-bg {
  display: none;
}

/* === Page BG（上下のクリーム領域：曲線SVG）=== */
.page-bg {
  position: absolute;
  left: 0;
  right: 0;
  z-index: -1;
  overflow: hidden;
  pointer-events: none;
  background-position: top center;
  background-size: 100% 100%;
  background-repeat: no-repeat;
}
/* 上半身: ヘッダー含むページTOP → 「もっと見る」の上 */
.page-bg--top {
  top: 0;
  height: 2900px; /* SP: もっと見る直前まで */
  background-image: url('../images/bg-curve-sp.svg');
}
/* 下半身: FAQ中盤 → フッター下端（固定フッター手前）*/
.page-bg--bottom {
  bottom: 0; /* SP: body padding-bottom で固定ボトムナビの上まで */
  height: 1560px;
  background-image: url('../images/bg-curve-sp.svg');
  transform: scaleY(-1);  /* SP用：curve at top にするため上下反転 */
}
@media (min-width: 1024px) {
  .page-bg--top {
    height: 2200px; /* PC: もっと見る直前まで */
    background-image: url('../images/bg-curve-pc.svg');
  }
  .page-bg--bottom {
    bottom: 0; /* PC: フッター下端まで */
    height: 1240px;
    background-image: url('../images/bg-curve-pc-alt.svg');
    transform: none;
  }
}

:where(.is-look-redesign h1,
.is-look-redesign h2,
.is-look-redesign h3,
.is-look-redesign h4) { line-height: var(--lh-tight); font-weight: 700; }

/* === Container === */
.container {
  width: 100%;
  max-width: var(--container);
  margin: 0 auto;
  padding: 0 16px;
}
@media (min-width: 1024px) { .container { padding: 0 24px; } }

/* === Cocoon ページ用 中央コンテナ ===
 * <main> 直下に出る Cocoon の <article> をラップして中央配置にする。
 * header.php / footer.php で look_is_redesign_page() が false のときだけ
 * 出力される。固定ページ・通常投稿の本文は読みやすさを優先し 880px に
 * 抑え、Cocoon 標準の見出し装飾を LOOK トーンへ上書きする。 */
.look-page-content {
  width: 100%;
  max-width: 880px;
  margin: 0 auto;
  padding: var(--sp-6) 16px;
  font-size: var(--fs-lg);
  line-height: var(--lh-base);
  color: var(--color-text);
}
@media (min-width: 1024px) {
  .look-page-content {
    padding: var(--sp-7) 24px;
  }
}

/* article ヘッダー（タイトル領域）*/
.look-page-content .article-header,
.look-page-content .entry-header {
  margin-bottom: var(--sp-6);
}
.look-page-content .entry-title {
  font-size: 28px;
  font-weight: 900;
  line-height: var(--lh-tight);
  color: var(--color-text);
  padding-bottom: var(--sp-4);
  border-bottom: 3px solid var(--color-primary);
  margin: 0 0 var(--sp-5);
}
@media (min-width: 1024px) {
  .look-page-content .entry-title { font-size: 34px; }
}

/* 本文タイポグラフィ：Cocoon 既定の見出し装飾を打ち消し、LOOK トーンへ */
.look-page-content .entry-content h2,
.look-page-content .entry-content h3,
.look-page-content .entry-content h4 {
  background: none;
  border: 0;
  padding: 0;
  color: var(--color-text);
  line-height: var(--lh-tight);
  font-weight: 700;
}
.look-page-content .entry-content h2 {
  font-size: 22px;
  padding: var(--sp-2) 0 var(--sp-3) var(--sp-4);
  border-left: 6px solid var(--color-primary);
  margin: var(--sp-7) 0 var(--sp-4);
}
.look-page-content .entry-content h3 {
  font-size: 18px;
  padding: 0 0 0 var(--sp-3);
  border-left: 4px solid var(--color-accent);
  margin: var(--sp-6) 0 var(--sp-3);
}
.look-page-content .entry-content h4 {
  font-size: var(--fs-lg);
  margin: var(--sp-5) 0 var(--sp-2);
  color: var(--color-primary-dark);
}
@media (min-width: 1024px) {
  .look-page-content .entry-content h2 { font-size: 24px; }
  .look-page-content .entry-content h3 { font-size: 20px; }
}

/* 本文要素 */
.look-page-content .entry-content > * + * { margin-top: var(--sp-4); }
.look-page-content .entry-content p {
  margin: 0 0 var(--sp-4);
}
.look-page-content .entry-content a:not(.btn):not(.wp-block-button__link):not(.look-btn) {
  color: var(--color-primary);
  text-decoration: underline;
  text-underline-offset: 2px;
}
.look-page-content .entry-content a:not(.btn):not(.wp-block-button__link):not(.look-btn):hover {
  color: var(--color-primary-dark);
}
.look-page-content .entry-content ul,
.look-page-content .entry-content ol {
  margin: 0 0 var(--sp-4);
  padding-left: 1.5em;
}
.look-page-content .entry-content li { margin-bottom: var(--sp-2); }
.look-page-content .entry-content ul li::marker { color: var(--color-primary); }
.look-page-content .entry-content hr {
  border: 0;
  border-top: 1px solid var(--color-border);
  margin: var(--sp-6) 0;
}
.look-page-content .entry-content blockquote {
  margin: var(--sp-5) 0;
  padding: var(--sp-4) var(--sp-5);
  background: var(--color-bg-cream);
  border-left: 4px solid var(--color-accent);
  border-radius: var(--radius-md);
  color: var(--color-text-sub);
}
.look-page-content .entry-content img {
  max-width: 100%;
  height: auto;
  border-radius: var(--radius-md);
}
/* テーブル: 罫線・余白のみ整える。背景色はエディタの設定を尊重する。 */
.look-page-content .entry-content .wp-block-table { margin: var(--sp-4) 0; }
.look-page-content .entry-content table {
  width: 100%;
  border-collapse: collapse;
}
.look-page-content .entry-content th,
.look-page-content .entry-content td {
  padding: var(--sp-3) var(--sp-4);
  border: 1px solid var(--color-border);
  text-align: left;
  vertical-align: top;
}
.look-page-content .entry-content th { font-weight: 700; }

/* === Utility === */
/* SP: .u-hidden-pc は表示を維持（元のdisplayをrevert）、.u-hidden-sp は非表示 */
.u-hidden-pc { /* SP: 表示（デフォルトを維持） */ }
.u-hidden-sp { display: none !important; }
@media (min-width: 1024px) {
  .u-hidden-pc { display: none !important; }
  .u-hidden-sp { display: revert !important; }
}

/* === 待機中バッジ ===
 * 旧: badge-standby.svg（「待機中」を焼き込んだ固定画像）
 * 新: 赤背景の角丸ピル + 動的テキスト「X台待機中」。 functions.php
 *     look_render_standby_badge() で出力。文脈別の位置・サイズ調整は
 *     .list-card__standby / .detail-hero__standby / .nearby__standby 側で。 */
.standby-badge {
  display: inline-block;
  background: var(--color-standby-bg);
  color: #fff;
  font-weight: 700;
  font-size: var(--fs-sm);
  line-height: 1;
  padding: 6px 10px;
  border-radius: var(--radius-pill);
  white-space: nowrap;
  letter-spacing: 0.02em;
}

/* === Button base ===
 * .look-btn は LOOK 新デザインの汎用ボタン。グローバル適用。
 * Cocoon ボタンブロックの内部 .btn とは衝突しない命名。 */
.look-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--sp-2);
  padding: var(--sp-3) var(--sp-5);
  border-radius: var(--radius-pill);
  font-weight: 700;
  transition: transform 0.1s;
}
.look-btn--primary {
  background: var(--color-primary);
  color: #fff;
  box-shadow: var(--shadow-btn);
}
.look-btn--primary:hover { transform: translateY(1px); box-shadow: 0 2px 0 var(--color-primary-dark); }
.look-btn--primary:active {
  transform: translateY(2px);
  box-shadow: 0 0 0 var(--color-primary-dark);
}
.look-btn:focus-visible {
  outline: 2px solid var(--color-primary);
  outline-offset: 2px;
}

/* === Site Header === */
.site-header {
  position: sticky;
  top: 0;
  z-index: 100;
  background: #fff;  /* ページ背景と分離させた白ヘッダー */
  border-bottom: 1px solid var(--color-border);
  height: var(--header-h-sp);
}
@media (min-width: 1024px) { .site-header { height: var(--header-h); } }

.site-header__inner {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 100%;
  position: relative;
}
@media (min-width: 1024px) {
  .site-header__inner {
    justify-content: space-between;
  }
}

.site-header__logo { text-decoration: none; }
.site-header__logo img { height: 28px; width: auto; display: block; }
@media (min-width: 1024px) { .site-header__logo img { height: 32px; } }

.site-header__nav ul {
  display: flex;
  gap: var(--sp-5);
  font-size: var(--fs-sm);
  font-weight: 500;
}

/* === Hamburger === */
.hamburger {
  position: absolute;
  left: 16px;
  top: 50%;
  transform: translateY(-50%);
  width: 28px;
  height: 28px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 5px;
}
.hamburger span {
  display: block;
  width: 24px;
  height: 2px;
  background: var(--color-text);
  transition: transform 0.2s, opacity 0.2s;
}
body.is-drawer-open .hamburger span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
body.is-drawer-open .hamburger span:nth-child(2) { opacity: 0; }
body.is-drawer-open .hamburger span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }
.hamburger:focus-visible {
  outline: 2px solid var(--color-primary);
  outline-offset: 4px;
  border-radius: 4px;
}

/* === Drawer === */
.drawer {
  position: fixed;
  inset: var(--header-h-sp) 0 0 0;
  z-index: 90;
  pointer-events: none;
}
.drawer__overlay {
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.4);
  opacity: 0;
  transition: opacity 0.3s;
}
.drawer__body {
  position: absolute;
  top: 0;
  left: 0;
  width: 55%;
  max-width: 320px;
  height: 100%;
  background: var(--color-bg);
  transform: translateX(-100%);
  transition: transform 0.3s;
  padding: var(--sp-6) var(--sp-4);
}
.drawer__body ul { display: flex; flex-direction: column; gap: var(--sp-5); font-size: var(--fs-lg); font-weight: 700; padding-left: initial;}

body.is-drawer-open { overflow: clip; }
body.is-drawer-open .drawer { pointer-events: auto; }
body.is-drawer-open .drawer__overlay { opacity: 1; }
body.is-drawer-open .drawer__body { transform: translateX(0); }
.drawer__body a:focus-visible,
.site-header__nav a:focus-visible {
  outline: 2px solid var(--color-primary);
  outline-offset: 2px;
  border-radius: 4px;
}

/* === Hero === */
.hero {
  background: transparent;
  padding: var(--sp-6) 0 var(--sp-7);
  position: relative;
  /* overflow: hidden を外して透かしが下の area-search まで延長できるように */
}
.hero > .container { position: relative; z-index: 2; }
.hero__inner {
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
}
.hero__catch {
  /* h1 親テーマデフォルト打ち消し */
  position: relative;
  display: inline-block;
  margin: 0 0 var(--sp-4);
  padding: 0 var(--sp-5);
  border: 0;
  background: transparent;
  font-size: var(--fs-xl);
  font-weight: 700;
  line-height: var(--lh-tight, 1.3);
}
.hero__catch::before,
.hero__catch::after {
  content: "";
  position: absolute;
  top: 50%;
  width: 2px;
  height: 1.2em;
  background: var(--color-primary);
}
.hero__catch::before { left: 0; transform: translateY(-50%) rotate(-15deg); }
.hero__catch::after { right: 0; transform: translateY(-50%) rotate(15deg); }

.hero__cta {
  width: 100%;
  max-width: 420px;
  padding: var(--sp-4) var(--sp-5);
  font-size: var(--fs-xl);
  margin-bottom: var(--sp-4);
  gap: var(--sp-3);
}
/* SVGをそのままボタン画像として使う場合の上書き */
.hero__cta--img {
  padding: 0;
  background: transparent;
  box-shadow: none;
  display: block;
  transition: transform 0.1s;
}
.hero__cta--img img { display: block; width: 100%; height: auto; }
.hero__cta--img:hover { transform: translateY(1px); }
.hero__cta--img:active { transform: translateY(2px); }

.hero__sub {
  font-size: var(--fs-sm);
  font-weight: 700;
  margin-bottom: var(--sp-2);
}

.hero__search {
  display: flex;
  max-width: 420px;
  margin: 0 auto;
  background: #fff;
  border-radius: var(--radius-pill);
  border: 2px solid var(--color-primary-soft);
  padding: 4px;
}
.hero__search input {
  flex: 1;
  border: 0;
  outline: 0;
  padding: 0 var(--sp-4);
  background: transparent;
  color: var(--color-primary);
  font-weight: 500;
}
.hero__search input::placeholder { color: var(--color-primary); opacity: 0.6; }
.hero__search-btn {
  padding: var(--sp-2) var(--sp-4);
  font-size: var(--fs-md);
  box-shadow: none;
}

@media (min-width: 1024px) {
  .hero { padding: var(--sp-7) 0; }
  .hero__catch { font-size: var(--fs-2xl); }
  .hero__cta { font-size: var(--fs-2xl); max-width: 520px; padding: var(--sp-5) var(--sp-6); }
}

/* === Area Search === */
.area-search { padding: var(--sp-7) 0; position: relative; overflow: hidden; }
.area-search > .container { position: relative; z-index: 1; }
.area-search__title {
  display: none;
  text-align: center;
  color: var(--color-primary);
  font-size: var(--fs-lg);
  margin-bottom: var(--sp-5);
}

.area-search__map {
  text-align: center;
  margin-bottom: var(--sp-5);
}
.area-search__map-inner {
  position: relative;
  display: inline-block;
  width: 100%;
  max-width: 683px; /* 420 * 732 / 450.2 ≒ 683 */
  aspect-ratio: 732 / 450.2;
}
.area-search__map-inner img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  display: block;
}
.area-search__map-region {
  position: absolute;
  border-radius: 4px;
  transition: background-color 0.15s;
}
.area-search__map-region:hover,
.area-search__map-region:focus-visible {
  background-color: rgba(200, 24, 42, 0.12);
  outline: none;
}

/* 繁華街リスト空状態 */
.pill-list__empty {
  width: 100%;
  text-align: center;
  color: var(--color-text-muted, #888);
  font-size: var(--fs-sm);
  padding: var(--sp-3) 0;
  list-style: none;
}

/* カードグリッド Ajax ローディング */
.card-grid.is-loading {
  opacity: 0.55;
  pointer-events: none;
  transition: opacity 0.15s;
}
.nearby__empty {
  list-style: none;
  text-align: center;
  color: var(--color-text-muted, #888);
  padding: var(--sp-4) 0;
  grid-column: 1 / -1;
}

.area-search__panel {
  background: transparent;
  padding: 0;
}
.area-search__panel-title {
  text-align: center;
  color: var(--color-primary);
  font-weight: 700;
  margin: var(--sp-4) 0 var(--sp-3);
  font-size: var(--fs-md);
}
.area-search__panel-title::before { content: "▼ "; }

/* === Pill === */
.pill-list {
  display: flex;
  flex-wrap: wrap;
  gap: var(--sp-2);
  justify-content: center;
  margin-bottom: var(--sp-4);
  padding-left: initial;
}
.pill {
  padding: 6px 14px;
  border-radius: var(--radius-pill);
  background: #fff;
  border: 1px solid var(--color-primary-soft);
  color: var(--color-primary);
  font-size: var(--fs-sm);
  font-weight: 500;
}
.pill--active { background: var(--color-primary); color: #fff; border-color: var(--color-primary); }
.pill--outline { background: #fff; border-color: var(--color-primary); color: var(--color-primary); }
.pill-list--area .pill { font-size: var(--fs-xs); }

@media (min-width: 1024px) {
  .area-search__title { display: block; font-size: var(--fs-xl); }
  .pill { font-size: var(--fs-md); padding: 8px 18px; }
}

/* === Nearby / Card Grid === */
.nearby { padding: var(--sp-6) 0 var(--sp-7); background: transparent; position: relative; overflow: hidden; }
.nearby > .container { position: relative; z-index: 1; }
.breadcrumb {
  font-size: var(--fs-sm);
  color: var(--color-text-sub);
  margin-bottom: var(--sp-4);
}

.card-grid {
  padding-left: initial;
  display: grid;
  gap: var(--sp-4);
  grid-template-columns: 1fr;
}
@media (min-width: 768px)  { .card-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1024px) { .card-grid { grid-template-columns: repeat(3, 1fr); gap: var(--sp-5); } }

.card {
  background: #fff;
  border: 1px solid var(--color-accent-soft);
  border-radius: var(--radius-md);
  padding: var(--sp-3) var(--sp-4);
  box-shadow: var(--shadow-card);
  display: flex;
  flex-direction: column;
  gap: var(--sp-2);
}
.card__title { font-size: var(--fs-lg); font-weight: 700; }
.card__standby-row { margin: 0; line-height: 1; }
.card__sub { font-size: var(--fs-sm); color: var(--color-text-sub); }
.card__meta { font-size: var(--fs-sm); line-height: var(--lh-tight); }
.card__meta p + p { margin-top: 4px; }
.card__rating { color: var(--color-star); font-weight: 700; flex-shrink: 0; }
.card__rating span { color: var(--color-text-sub); font-weight: 400; font-size: var(--fs-xs); margin-left: 4px; }

/* カード下段: 評価（左） + 今スグ電話（右、カード幅の半分）*/
.card__footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--sp-3);
  flex-wrap: wrap;
}
/* 電話ボタンを持つカードのみ底揃え（評価だけのカードは自然位置のまま）*/
.card__footer:has(.card__tel) { margin-top: auto; }
.card__tel {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--sp-2);
  background: var(--color-primary);
  color: #fff;
  font-weight: 700;
  font-size: var(--fs-lg);
  padding: var(--sp-2) var(--sp-4);
  border-radius: var(--radius-pill);
  box-shadow: var(--shadow-btn);
  white-space: nowrap;
  flex: 0 0 50%;
  min-width: 0;
  transition: transform 0.1s, box-shadow 0.1s;
}
.card__tel svg { width: 18px; height: 18px; flex-shrink: 0; }
.card__tel:hover { transform: translateY(1px); box-shadow: 0 2px 0 var(--color-primary-dark); }
.card__tel:active { transform: translateY(2px); box-shadow: 0 0 0 var(--color-primary-dark); }

.tag {
  display: inline-block;
  padding: 2px 8px;
  border: 1px solid var(--color-accent);
  border-radius: var(--radius-sm);
  color: var(--color-accent);
  font-size: var(--fs-xs);
  margin-right: var(--sp-2);
}

.nearby__more { text-align: center; margin-top: var(--sp-5); }
.more-btn {
  position: relative;
  font-weight: 500;
  color: var(--color-text-sub);
  font-size: var(--fs-sm);
  padding-right: 0;
}
.more-btn__icon {
  position: absolute;
  left: 100%;
  top: 50%;
  transform: translateY(-50%);
  margin-left: 6px;
  width: 14px;
  height: 14px;
  color: currentColor;
}

/* === Shared section title === */
.section-eyebrow {
  text-align: center;
  font-size: var(--fs-sm);
  color: var(--color-accent);
  margin-bottom: var(--sp-2);
}
.section-eyebrow.en { font-weight: 500; letter-spacing: 0.1em; }
.section-eyebrow--oo img {
  display: inline-block;
  width: auto;
  height: 24px;
}
.section-eyebrow--stars img {
  display: inline-block;
  width: auto;
  height: 24px;
}
.section-eyebrow--icon img {
  display: inline-block;
  width: auto;
  height: 28px;
}
.section-title {
  text-align: center;
  font-size: var(--fs-2xl);
  margin-bottom: var(--sp-4);
}
.section-lead {
  text-align: center;
  color: var(--color-text-sub);
  font-size: var(--fs-sm);
  margin-bottom: var(--sp-6);
}

/* === CTA block === */
.cta-block { padding: var(--sp-6) 0; text-align: center; }
.cta-block__btn { padding: var(--sp-5) var(--sp-6); font-size: var(--fs-lg); width: 80%; height: 50px; max-width: 520px; }

/* === Features Three === */
.features-three { padding: var(--sp-7) 0; }
.features-three__grid {
  display: grid;
  gap: var(--sp-5);
  grid-template-columns: 1fr;
}
@media (min-width: 1024px) { .features-three__grid { grid-template-columns: repeat(3, 1fr); } }
.features-three__item h3 {
  font-size: var(--fs-lg);
  color: var(--color-primary);
  margin-bottom: var(--sp-2);
}
.features-three__item p { font-size: var(--fs-sm); color: var(--color-text-sub); }

/* === How to === */
.how-to { padding: var(--sp-7) 0; background: transparent; }
.how-to__list {
  display: grid;
  gap: var(--sp-4);
  grid-template-columns: 1fr;
  max-width: 800px;
  margin: 0 auto;
}
@media (min-width: 1024px) { .how-to__list { grid-template-columns: repeat(3, 1fr); } }
.how-to__step {
  background: #fff;
  border: 1px solid var(--color-accent-soft);
  border-radius: var(--radius-md);
  padding: var(--sp-5) var(--sp-4);
  text-align: center;
}
.how-to__num { color: var(--color-primary); font-weight: 700; }
.how-to__name { font-weight: 700; font-size: var(--fs-lg); margin: var(--sp-2) 0; }
.how-to__icon { font-size: 32px; color: var(--color-accent); margin: var(--sp-2) 0; }
.how-to__icon img { display: inline-block; width: auto; height: 48px; vertical-align: middle; }
.how-to__desc { font-size: var(--fs-sm); color: var(--color-text-sub); }

/* === Features Grid === */
.features-grid { padding: var(--sp-7) 0; }
.features-grid__grid {
  display: grid;
  gap: var(--sp-5);
  grid-template-columns: 1fr;
}
@media (min-width: 1024px) { .features-grid__grid { grid-template-columns: repeat(3, 1fr); } }
.features-grid__grid h3 {
  font-weight: 700;
  color: var(--color-text);
  margin-bottom: var(--sp-2);
}
.features-grid__grid p { font-size: var(--fs-sm); color: var(--color-text-sub); }

/* === Region Links === */
.region-links { padding: var(--sp-7) 0; }
.region-links__list {
  max-width: 720px;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  gap: var(--sp-2);
}
.region-links__list a {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: var(--sp-3) var(--sp-4);
  border-bottom: 1px solid var(--color-border);
  font-weight: 700;
  color: var(--color-text);
}

/* === Info Block (price/vs-taxi/cautions共通) === */
.info-block { padding: var(--sp-6) 0; }
.info-block__inner { max-width: 720px; margin: 0 auto; text-align: center; }
.info-block p { font-size: var(--fs-sm); line-height: var(--lh-base); margin-bottom: var(--sp-2); }
.info-block .primary { color: var(--color-primary); }
.info-block .link { color: var(--color-primary); text-decoration: underline; font-weight: 700; }

.bullet-list {
  text-align: left;
  display: inline-block;
  font-size: var(--fs-sm);
  margin: var(--sp-2) 0;
}
.bullet-list li::before { content: "・"; color: var(--color-primary); }

/* === FAQ ===
 * .look-faq は LOOK 新デザインの FAQ セクション。グローバル適用。
 * Cocoon FAQ ブロック内部の .faq とは別物。
 * BEM 子クラス（.faq__list / .faq__item / .faq__q / .faq__a）は Cocoon と
 * 衝突しないため据え置き。 */
.look-faq { padding: var(--sp-7) 0; }
.faq__list { max-width: 720px; margin: 0 auto; }
.faq__item {
  border-bottom: 1px solid var(--color-border);
}
.faq__item summary {
  display: flex;
  align-items: center;
  gap: var(--sp-3);
  padding: var(--sp-4) var(--sp-3);
  font-weight: 700;
  position: relative;
}
.faq__item summary::after {
  content: "＋";
  margin-left: auto;
  color: var(--color-primary);
  font-size: var(--fs-xl);
  font-weight: 700;
  transition: transform 0.2s;
}
.faq__item[open] summary::after { content: "−"; }
.faq__q {
  color: var(--color-primary);
  border: 1px solid var(--color-primary);
  border-radius: 50%;
  width: 24px; height: 24px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: var(--fs-sm);
  flex-shrink: 0;
}
.faq__a {
  padding: 0 var(--sp-3) var(--sp-4) calc(var(--sp-3) + 24px + var(--sp-3));
  color: var(--color-text-sub);
  font-size: var(--fs-sm);
}

/* === Banners === */
.banners { padding: var(--sp-5) 0; background: transparent; }
.banners__inner {
  display: grid;
  gap: var(--sp-3);
  grid-template-columns: 1fr;
  max-width: 720px;
}
@media (min-width: 1024px) { .banners__inner { grid-template-columns: 1fr 1fr; gap: var(--sp-4); max-width: var(--container); } }
.banner {
  display: block;
  border-radius: var(--radius-md);
  overflow: hidden;
  border: 1px solid var(--color-border);
  background: #fff;
  min-height: 120px;
}

/* === CTA Bottom === */
.cta-bottom { padding: var(--sp-7) 0; text-align: center; background: transparent; }
.cta-bottom__inner { display: flex; flex-direction: column; align-items: center; gap: var(--sp-5); }
.cta-bottom__logo { height: 36px; width: auto; }
@media (min-width: 1024px) { .cta-bottom__logo { height: 48px; } }
.cta-bottom__btn { padding: var(--sp-4) var(--sp-6); font-size: var(--fs-xl); width: 100%; max-width: 520px; }
/* SVGピルをそのまま使うボトムCTA */
.cta-bottom__btn--img {
  padding: 0;
  background: transparent;
  box-shadow: none;
  display: block;
  transition: transform 0.1s;
}
.cta-bottom__btn--img img { display: block; width: 100%; height: auto; }
.cta-bottom__btn--img:hover { transform: translateY(1px); }
.cta-bottom__btn--img:active { transform: translateY(2px); }

/* === Area Accordion ===
   PDF / モック準拠: 上部 3 ピル（地域モード / 繁華街モード / 検索ボタン）
   下部 1 大パネル → 8 リージョン行クリックで配下ピル展開、ピル単一選択 */
.area-accordion { padding: var(--sp-6) 0; background: transparent; }
.area-accordion__lead {
  text-align: center;
  font-size: var(--fs-sm);
  color: var(--color-text-sub);
  margin-bottom: var(--sp-5);
}

/* 上部: モード切替タブ + 検索ボタン */
.area-accordion__tabs {
  display: grid;
  gap: var(--sp-3);
  grid-template-columns: 1fr;
  max-width: 1080px;
  margin: 0 auto var(--sp-4);
}
@media (min-width: 1024px) {
  .area-accordion__tabs { grid-template-columns: 1fr 1fr; }
}
.area-accordion__tab {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--sp-3);
  background: #fff;
  border: 1px solid var(--color-primary);
  border-radius: var(--radius-pill);
  padding: var(--sp-3) var(--sp-5);
  color: var(--color-primary);
  font-weight: 700;
  font-size: var(--fs-md);
  cursor: pointer;
  transition: background 0.15s, color 0.15s;
}
.area-accordion__tab:hover { background: var(--color-primary-soft); }
.area-accordion__tab.is-active {
  background: var(--color-primary);
  color: #fff;
}
.area-accordion__tab-icon {
  font-size: var(--fs-xl);
  font-weight: 700;
  line-height: 1;
}
/* 下部: モード別パネル */
.area-accordion__panel {
  border: 1px solid var(--color-primary);
  border-radius: var(--radius-md);
  background: #fff;
  max-width: 1080px;
  margin: 0 auto;
  padding: 0 var(--sp-5);
}
.area-accordion__panel[hidden] { display: none; }

.area-accordion__regions {
  list-style: none;
  margin: 0;
  padding: 0;
}
.area-accordion__region + .area-accordion__region {
  border-top: 1px solid var(--color-border);
}
.area-accordion__region-toggle {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--sp-3);
  padding: var(--sp-3) 0;
  background: transparent;
  border: 0;
  font-weight: 700;
  font-size: var(--fs-md);
  color: var(--color-text);
  cursor: pointer;
  text-align: left;
}
.area-accordion__region-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 24px;
  height: 24px;
  border-radius: 50%;
  background: var(--color-primary);
  color: #fff;
  font-size: var(--fs-md);
  font-weight: 700;
  flex-shrink: 0;
  line-height: 1;
}
.area-accordion__pills {
  display: flex;
  flex-wrap: wrap;
  gap: var(--sp-2);
  padding: 0 0 var(--sp-3);
}
.area-accordion__pills[hidden] { display: none; }
.area-accordion__pill {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: #fff;
  border: 1px solid var(--color-primary);
  border-radius: var(--radius-pill);
  padding: 6px var(--sp-4);
  color: var(--color-primary);
  font-weight: 700;
  font-size: var(--fs-sm);
  cursor: pointer;
  min-width: 64px;
  text-decoration: none;
  transition: background 0.15s, color 0.15s;
}
.area-accordion__pill:hover {
  background: var(--color-primary);
  color: #fff;
}

/* === News Archive / Post Detail（site-news 一覧 + 投稿詳細） === */
.news-archive { padding: var(--sp-7) 0 var(--sp-8); }
.news-archive__head { text-align: center; margin-bottom: var(--sp-6); }

.news-list { display: flex; flex-direction: column; gap: var(--sp-3); margin: 0 auto; max-width: 800px; list-style: none; padding-left: 0; }
.news-card {
  display: block;
  background: #fff;
  border: 1px solid var(--color-accent-soft);
  border-radius: var(--radius-md);
  padding: var(--sp-4) var(--sp-5);
  box-shadow: var(--shadow-card);
  transition: transform 0.1s, box-shadow 0.1s;
}
.news-card:hover { transform: translateY(-1px); box-shadow: 0 4px 12px rgba(0, 0, 0, 0.08); }
.news-card__date {
  display: inline-block;
  font-size: var(--fs-sm);
  color: var(--color-accent);
  font-weight: 500;
  letter-spacing: 0.05em;
  margin-bottom: var(--sp-2);
}
.news-card__title {
  font-size: var(--fs-lg);
  color: var(--color-text);
  margin-bottom: var(--sp-2);
  line-height: var(--lh-tight);
}
.news-card__excerpt {
  font-size: var(--fs-sm);
  color: var(--color-text-sub);
  margin-bottom: var(--sp-2);
}
.news-card__more {
  display: inline-block;
  font-size: var(--fs-sm);
  color: var(--color-primary);
  font-weight: 700;
}

.news-empty {
  text-align: center;
  color: var(--color-text-sub);
  padding: var(--sp-7) 0;
}

.news-pagination {
  display: flex;
  justify-content: center;
  gap: var(--sp-2);
  margin-top: var(--sp-6);
  flex-wrap: wrap;
}
.news-pagination .page-numbers {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 36px;
  height: 36px;
  padding: 0 var(--sp-3);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm);
  font-size: var(--fs-sm);
  color: var(--color-text);
  background: #fff;
}
.news-pagination .page-numbers.current {
  background: var(--color-primary);
  color: #fff;
  border-color: var(--color-primary);
}
.news-pagination .page-numbers:hover:not(.current) { border-color: var(--color-primary); color: var(--color-primary); }

.post-breadcrumb {
  font-size: var(--fs-sm);
  color: var(--color-text-sub);
  padding: var(--sp-4) var(--sp-4);
  display: flex;
  align-items: center;
  gap: var(--sp-2);
  flex-wrap: wrap;
}
.post-breadcrumb a { color: var(--color-primary); }
.post-breadcrumb__sep { color: var(--color-text-sub); }
.post-breadcrumb__current { color: var(--color-text); }

.post-detail { padding: var(--sp-4) 0 var(--sp-8); }
.post-detail__inner { max-width: 800px; }
.post-detail__head {
  text-align: center;
  padding: var(--sp-5) 0 var(--sp-6);
  border-bottom: 1px solid var(--color-border);
  margin-bottom: var(--sp-6);
}
.post-detail__date {
  display: inline-block;
  font-size: var(--fs-sm);
  color: var(--color-accent);
  font-weight: 500;
  letter-spacing: 0.05em;
  margin-bottom: var(--sp-3);
}
.post-detail__title {
  font-size: var(--fs-2xl);
  color: var(--color-text);
  line-height: var(--lh-tight);
}
.post-detail__body {
  font-size: var(--fs-md);
  line-height: var(--lh-base);
  color: var(--color-text);
}
.post-detail__body > * + * { margin-top: var(--sp-4); }
.post-detail__body h2 {
  font-size: var(--fs-xl);
  color: var(--color-primary);
  border-left: 4px solid var(--color-primary);
  padding-left: var(--sp-3);
  margin-top: var(--sp-6);
}
.post-detail__body h3 {
  font-size: var(--fs-lg);
  color: var(--color-text);
  margin-top: var(--sp-5);
}
.post-detail__body a { color: var(--color-primary); text-decoration: underline; }
.post-detail__body img { max-width: 100%; height: auto; border-radius: var(--radius-sm); }
.post-detail__body ul,
.post-detail__body ol { padding-left: var(--sp-5); }
.post-detail__body li + li { margin-top: var(--sp-2); }
.post-detail__body blockquote {
  border-left: 4px solid var(--color-accent-soft);
  padding: var(--sp-2) var(--sp-4);
  color: var(--color-text-sub);
  background: var(--color-bg-cream);
  border-radius: var(--radius-sm);
}

.post-detail__back { text-align: center; margin-top: var(--sp-7); }

/* === Site Footer === */
.site-footer {
  background: transparent;
  padding: var(--sp-7) 0 var(--sp-5);
}
.site-footer__inner {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--sp-5);
  max-width: 960px;
}
@media (min-width: 768px) {
  .site-footer__inner { grid-template-columns: repeat(3, 1fr); }
}
.site-footer__title {
  font-size: var(--fs-md);
  color: var(--color-text);
  margin-bottom: var(--sp-3);
}
.site-footer__col ul { display: flex; flex-direction: column; gap: var(--sp-2); list-style: none; padding-left: 0; }
.site-footer__col a {
  font-size: var(--fs-sm);
  color: var(--color-primary);
}
.copyright {
  text-align: center;
  margin-top: var(--sp-5);
}

/* === Bottom Nav (SPのみ) === */
.bottom-nav {
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  background: #fff;
  border-top: 1px solid var(--color-border);
  height: var(--bottom-nav-h);
  z-index: 80;
}
.bottom-nav__list {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  height: 100%;
  align-items: center;
  padding-left: initial;
}
.bottom-nav a {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 2px;
  font-size: var(--fs-xs);
  color: var(--color-text-sub);
}
.bottom-nav__icon { width: 22px; height: 22px; }
.bottom-nav__primary-icon svg { width: 26px; height: 26px; }

/* グローバル/ドロワーナビ & カード内の汎用アイコン */
.nav-icon { width: 18px; height: auto; vertical-align: -3px; margin-right: 6px; flex-shrink: 0; }
.site-header__nav a,
.drawer__body a { display: inline-flex; align-items: center; }
.drawer__body a { gap: 4px; }
.breadcrumb__icon { width: 18px; height: auto; vertical-align: -4px; margin-right: 4px; display: inline; color: var(--color-primary); }
.card__icon { width: 14px; height: 14px; vertical-align: -2px; margin-right: 4px; }
.bottom-nav__primary { position: relative; }
.bottom-nav__primary a {
  color: var(--color-primary);
  font-weight: 600;
  padding-top: 30px; /* 円の下端がラベルに重ならないよう確保 */
}
.bottom-nav__primary-icon {
  position: absolute;
  top: -28px;
  left: 50%;
  transform: translateX(-50%);
  width: 52px;
  height: 52px;
  border-radius: 50%;
  background: #fff;
  border: 2px solid var(--color-primary);
  color: var(--color-primary);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 22px;
  line-height: 1;
  box-shadow: var(--shadow-card);
}

/* SPのみbody下部にパディング（bottom-navに隠れないように） */
@media (max-width: 1023px) {
  body { padding-bottom: var(--bottom-nav-h); }
}

/* === 背景の「O」透かし装飾 === */
.bg-watermark {
  position: absolute;
  pointer-events: none;
  z-index: 0;
  opacity: 0.6;
}
.bg-watermark img {
  display: block;
  width: 100%;
  height: auto;
}
/* Hero セクション右上に見切れ配置（SP専用、vw基準）*/
.bg-watermark--hero {
  top: 10vw;
  right: -36vw;   /* 右端から "O" の左半分が見切れて見える（15pxほど左寄せ）*/
  width: 90vw;
  opacity: 0.75;
  z-index: 0;     /* コンテナの下・bodyの page-bg の上 */
}
@media (min-width: 1024px) {
  .bg-watermark--hero { display: none; }
}

/* エリア検索の右側に見切れ配置（PC専用、vw基準）*/
.bg-watermark--map { display: none; }
@media (min-width: 1024px) {
  .bg-watermark--map {
    display: block;
    top: 3vw;
    /* bg-o-pc-a.svg の clippath 右端 (x=1164/1400.39≒83%) がビューポート内に
       入るとハードな縦エッジが見えるため、right を深くしてビューポート外へ逃がす */
    right: -12vw;
    width: 45vw;
    opacity: 0.6;
  }
}
/* お近くの運転代行（カード列の右側に見切れて配置） */
.bg-watermark--cards {
  top: 30vw;
  right: -25vw;
  width: 95vw;
  opacity: 0.6;
}
@media (min-width: 1024px) {
  .bg-watermark--cards {
    top: 8vw;
    right: -8vw;
    width: 40vw;
    opacity: 0.5;
  }
}

/* === 戻るトップボタン === */
.back-to-top {
  position: fixed;
  right: 16px;
  bottom: calc(var(--bottom-nav-h) + 16px);
  width: 44px;
  height: 44px;
  border-radius: 50%;
  background: #fff;
  border: 1px solid var(--color-border);
  box-shadow: var(--shadow-card);
  color: var(--color-text-sub);
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.2s, visibility 0.2s, transform 0.1s;
  z-index: 70;
}
.back-to-top svg { width: 20px; height: 20px; }
.back-to-top.is-visible { opacity: 1; visibility: visible; }
.back-to-top:hover { transform: translateY(-2px); }
.back-to-top:focus-visible { outline: 2px solid var(--color-primary); outline-offset: 2px; }

/* term_page コンテンツ全体のラッパー
 * look_render_term_page_content() で囲まれる div。
 * 内部の Gutenberg ブロックがコンテナ最大幅内で中央寄せされるよう
 * .container 同等の制約を当てる。
 */
.look-term-page-content {
  width: 100%;
  max-width: var(--container);
  margin: 0 auto;
  padding: var(--sp-6) 16px;
}
@media (min-width: 1024px) {
  .look-term-page-content { padding: var(--sp-8) 24px; }
}

@media (min-width: 1024px) {
  :root {
    --fs-2xl: 28px;
    --color-bg-cream: #fafafb;  /* PC: オフホワイト（SVG曲線の色と一致）*/
  }
  .back-to-top { right: 32px; bottom: 32px; width: 52px; height: 52px; }
  .back-to-top svg { width: 24px; height: 24px; }
}
