/* =========================================================================
   GMSMap - app.css
   - モバイルファースト / 親指ゾーン重視
   - CUD（Color Universal Design）+ WCAG AA（テキスト 4.5:1 / UI 3:1）
   - 言語フリー UI（テキスト依存を排除しアイコンで識別）
   - おもてなしトーン: ディープネイビー / アクションCTA / オフホワイト背景 /
     Material Symbols Rounded / M PLUS Rounded 1c（タイトル）
   ========================================================================= */

@import url('./design-tokens.css');

/* ----- Reset / Tokens ---------------------------------------------------- */
*,
*::before,
*::after {
  box-sizing: border-box;
}

html,
body {
  margin: 0;
  padding: 0;
  height: 100%;
  overflow: hidden;
  -webkit-text-size-adjust: 100%;
}

body {
  font-family: var(--font-body);
  color: var(--color-text);
  background: var(--color-bg);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

:root {
  /* === MAP 固有（design-tokens.css にないもの）=== */
  --pin-size: 36px;
  --pin-size-selected: 44px;
  --pin-border: 2px;
  --pin-shadow: 0 1px 3px rgba(0, 0, 0, 0.18), 0 2px 6px rgba(0, 0, 0, 0.10);
  --pin-shadow-hover: 0 2px 6px rgba(0, 0, 0, 0.22);
  --pin-shadow-selected: 0 4px 12px rgba(0, 0, 0, 0.28);

  /* === タップ（UX-MF-1: 例外なし 44px）=== */
  --tap: 44px;
  --tap-min: 44px;
  --tap-compact: 36px; /* ※ 装飾密度の高い局所要素のみ。主要操作には使わない */

  --safe-top: env(safe-area-inset-top, 0px);
  --safe-bottom: env(safe-area-inset-bottom, 0px);

  /* ヘッダー・メインブランド */
  --color-header: var(--color-brand-navy);
  --header-height: 58px;
  --home-carousel-height: 84px;
  --home-carousel-expanded-height: 84px;
  --home-carousel-collapsed-height: 32px;
  --home-carousel-live-height: 84px;
  --radius-md-brand: var(--radius-md);

  /* === 表面・影・配線（MAP 固有）=== */
  --color-surface-drawer: var(--surface-drawer);
  --color-surface-hero-end: var(--color-surface-elevated);
  --color-border-emphasis: rgba(10, 22, 40, 0.18);
  --color-border-brand: rgba(10, 22, 40, 0.12);
  --color-border-brand-subtle: rgba(10, 22, 40, 0.06);
  --color-border-faint: rgba(0, 0, 0, 0.08);
  --color-border-neutral: rgba(0, 0, 0, 0.10);
  --color-overlay-backdrop: rgba(15, 23, 42, 0.35);
  --color-overlay-toast: rgba(26, 26, 26, 0.92);
  --shadow-drawer-emphasis: -8px 0 28px rgba(15, 23, 42, 0.18);
  --shadow-chip-selected: 0 2px 10px rgba(10, 22, 40, 0.22);
  --shadow-filter-active: 0 3px 12px rgba(10, 22, 40, 0.28);
  --shadow-filter-active-sm: 0 2px 8px rgba(10, 22, 40, 0.20);
  --shadow-badge: 0 1px 4px rgba(0, 0, 0, 0.25);
  --shadow-card-composite: 0 2px 12px rgba(0, 0, 0, 0.06), 0 1px 3px rgba(15, 23, 42, 0.06);
  --shadow-elevated-composite: 0 4px 16px rgba(0, 0, 0, 0.08), 0 2px 6px rgba(15, 23, 42, 0.08);
  --color-cat-smoking-pulse: rgba(245, 158, 11, 0.55);
  --color-cat-trash-pulse: rgba(16, 185, 129, 0.55);
  --color-cat-toilet-pulse: rgba(14, 165, 233, 0.55);
  --color-cluster-mixed: #2C3358;
  --color-avatar-gradient-start: var(--color-brand-navy-soft);
  --color-avatar-gradient-end: var(--color-surface);
}

button {
  font: inherit;
  color: inherit;
  background: none;
  border: 0;
  padding: 0;
  cursor: pointer;
  -webkit-tap-highlight-color: transparent;
}

button:focus-visible {
  outline: 3px solid var(--color-primary);
  outline-offset: 2px;
}

/* Material Symbols Rounded（CDN で読込） */
.material-symbols-rounded {
  font-family: 'Material Symbols Rounded', sans-serif;
  font-weight: normal;
  font-style: normal;
  font-size: 24px;
  line-height: 1;
  letter-spacing: normal;
  display: inline-block;
  vertical-align: middle;
  direction: ltr;
  -webkit-font-smoothing: antialiased;
  font-feature-settings: 'liga';
  font-variation-settings: 'FILL' 1, 'wght' 500, 'GRAD' 0, 'opsz' 24;
}

.om-thanks-ms {
  font-size: 22px !important;
  font-variation-settings: 'FILL' 0, 'wght' 500, 'GRAD' 0, 'opsz' 24;
  line-height: 1;
  color: inherit;
}

.comment-thanks-readonly {
  display: inline-flex;
  align-items: center;
  gap: 3px;
  font-weight: 600;
  color: var(--color-warm-dark);
}

.comment-thanks-readonly .om-thanks-ms {
  font-size: 18px !important;
  color: var(--color-warm-dark);
}

[hidden] {
  display: none !important;
}

/* ----- Splash ------------------------------------------------------------ */
.splash {
  position: fixed;
  inset: 0;
  z-index: 1000;
  display: flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(155deg, var(--color-primary) 0%, var(--color-primary-dark) 100%);
  transition: opacity var(--motion-slow) var(--ease-standard);
}

.splash.is-hidden {
  opacity: 0;
  pointer-events: none;
}

.splash-content {
  position: relative;
  z-index: 1;
  text-align: center;
  padding: 0 36px;
}

.splash-logo {
  width: 84px;
  height: 84px;
  margin: 0 auto 26px;
  filter: drop-shadow(0 6px 20px rgba(0, 0, 0, 0.5));
}

.splash-logo-img {
  display: block;
  width: 100%;
  height: 100%;
}

.splash-logo svg {
  width: 100%;
  height: 100%;
}

.splash-title {
  margin: 0 0 6px;
  font-family: var(--font-display);
  font-size: 28px;
  font-weight: var(--font-weight-display);
  color: white;
  letter-spacing: var(--letter-spacing-display);
}

/* 正式名称（共有用 og:title と役割分担し、見出しより控えめに） */
.splash-brand-full {
  margin: 0 auto 10px;
  max-width: min(100%, 22em);
  font-family: var(--font-display);
  font-size: 13px;
  font-weight: 500;
  line-height: 1.4;
  color: rgba(255, 255, 255, 0.52);
  letter-spacing: 0.02em;
}

.splash-tagline {
  margin: 0 0 44px;
  font-size: 12px;
  color: rgba(255, 255, 255, 0.5);
  letter-spacing: 0.18em;
  text-transform: uppercase;
}

.splash-bar-wrap {
  width: 100px;
  height: 4px;
  background: rgba(255, 255, 255, 0.18);
  border-radius: var(--radius-sm);
  margin: 0 auto;
  overflow: hidden;
}

.splash-bar {
  height: 100%;
  width: 0;
  background: rgba(255, 255, 255, 0.82);
  border-radius: var(--radius-sm);
  animation: barLoad 1.6s ease-in-out forwards;
}

@keyframes barLoad {
  0%   { width: 0%; }
  50%  { width: 60%; }
  100% { width: 100%; }
}

/* ----- App / Map --------------------------------------------------------- */
.app {
  position: fixed;
  inset: 0;
  display: block;
}

.map {
  position: absolute;
  inset: 0;
  padding-top: calc(var(--header-height) + var(--safe-top) + var(--home-carousel-live-height, var(--home-carousel-expanded-height)));
  box-sizing: border-box;
  background: #e6e9ed;
}

body:not(:has(#home-spot-carousel)) .map {
  padding-top: calc(var(--header-height) + var(--safe-top));
}

/* ----- スポット写真ギャラリー（F-02 補足 / UX-MF-13） -------------------- */
.sheet-spot-gallery-wrap {
  padding: 0 20px 8px;
  border-bottom: 1px solid var(--color-border);
}

.sheet-spot-gallery-wrap[hidden] {
  display: none !important;
}

.spot-gallery {
  margin: 4px 0 4px;
}

.spot-gallery__viewport {
  overflow-x: auto;
  overflow-y: hidden;
  scroll-snap-type: x mandatory;
  -webkit-overflow-scrolling: touch;
  border-radius: 10px;
  outline: none;
  scroll-behavior: smooth;
}

.spot-gallery__viewport.is-single {
  overflow-x: hidden;
  scroll-snap-type: none;
}

@media (prefers-reduced-motion: reduce) {
  .spot-gallery__viewport {
    scroll-behavior: auto;
  }
}

.spot-gallery__track {
  display: flex;
  flex-direction: row;
  width: 100%;
}

.spot-gallery__slide {
  flex: 0 0 100%;
  width: 100%;
  scroll-snap-align: start;
  position: relative;
  background: var(--color-brand-navy-mid);
}

.spot-gallery__open {
  display: block;
  width: 100%;
  padding: 0;
  margin: 0;
  border: 0;
  cursor: zoom-in;
  line-height: 0;
  background: var(--color-brand-navy);
}

.spot-gallery__img {
  display: block;
  width: 100%;
  height: 38vw;
  max-height: 148px;
  object-fit: cover;
}

.spot-gallery__dots {
  display: flex;
  justify-content: center;
  gap: 6px;
  margin-top: 8px;
}

.spot-gallery__dots[hidden] {
  display: none !important;
}

.spot-gallery__dot {
  width: 7px;
  height: 7px;
  border-radius: 50%;
  padding: 0;
  border: 0;
  background: var(--color-border);
  cursor: pointer;
}

.spot-gallery__dot.is-active {
  background: var(--color-text);
}

/* ライトボックス（UX-LF-16: ピンチズーム） */
.photo-lightbox {
  position: fixed;
  inset: 0;
  z-index: 9500;
  display: flex;
  align-items: center;
  justify-content: center;
}

.photo-lightbox[hidden] {
  display: none !important;
}

.photo-lightbox__backdrop {
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.92);
}

.photo-lightbox__close {
  position: absolute;
  top: calc(12px + env(safe-area-inset-top, 0));
  right: calc(12px + env(safe-area-inset-right, 0));
  z-index: 2;
  width: 44px;
  height: 44px;
  border: 0;
  border-radius: 50%;
  font-size: 28px;
  line-height: 1;
  color: var(--color-on-primary);
  background: rgba(255, 255, 255, 0.12);
  cursor: pointer;
}

.photo-lightbox__stage {
  position: relative;
  z-index: 1;
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 56px 12px 40px;
  box-sizing: border-box;
}

.photo-lightbox__pinch {
  touch-action: none;
  overflow: hidden;
  max-width: 100%;
  max-height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
}

.photo-lightbox__img {
  max-width: 100%;
  max-height: calc(100vh - 120px);
  object-fit: contain;
  transform-origin: center center;
  will-change: transform;
}

/* ----- F-14 SCR-11: add-spot position mode ------------------------------- */
.add-spot-pin-layer {
  position: absolute;
  inset: 0;
  z-index: 9;
  pointer-events: none;
}

.add-spot-pin-crosshair {
  position: absolute;
  left: 50%;
  top: 50%;
  width: 72px;
  height: 72px;
  margin: -36px 0 0 -36px;
  color: var(--color-primary);
  filter: drop-shadow(0 1px 2px rgba(0, 0, 0, 0.35));
  pointer-events: none;
  transition: color 180ms ease, opacity 180ms ease;
}

.add-spot-pin-layer.is-outside-area .add-spot-pin-crosshair {
  color: var(--color-danger);
  opacity: 0.92;
}

.add-spot-pin-crosshair-svg {
  display: block;
  width: 72px;
  height: 72px;
}

.add-spot-pin-hint {
  position: absolute;
  left: 50%;
  bottom: calc(188px + var(--safe-bottom));
  transform: translateX(-50%);
  max-width: min(92%, 360px);
  margin: 0;
  padding: 8px 14px;
  border-radius: 12px;
  background: rgba(255, 255, 255, 0.96);
  border: 1px solid var(--color-brand-navy-tint);
  box-shadow: var(--shadow-2);
  font-size: 13px;
  line-height: 1.45;
  white-space: pre-line;
  text-align: center;
  color: var(--color-text);
  pointer-events: none;
  z-index: 12;
}

.add-spot-pin-layer.is-outside-area .add-spot-pin-hint {
  color: var(--color-danger);
  border-color: rgba(198, 40, 40, 0.28);
}

.add-spot-pin-bar {
  position: absolute;
  left: 50%;
  bottom: calc(110px + var(--safe-bottom));
  transform: translateX(-50%);
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 10px 12px;
  border-radius: var(--radius-pill);
  background: rgba(255, 255, 255, 0.96);
  border: 1px solid var(--color-brand-navy-tint);
  box-shadow: var(--shadow-2);
  pointer-events: auto;
  z-index: 13;
}

.add-spot-pin-btn {
  min-width: 48px;
  min-height: 48px;
  border-radius: 50%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: var(--color-surface);
  color: var(--color-text);
  border: 1px solid var(--color-border);
  transition: background-color var(--motion-base) var(--ease-standard), opacity var(--motion-base) var(--ease-standard), transform var(--motion-fast) var(--ease-standard);
}

.add-spot-pin-btn:active {
  transform: scale(0.94);
}

.add-spot-pin-btn .material-symbols-rounded {
  font-size: 26px;
  font-variation-settings: 'FILL' 1, 'wght' 500, 'GRAD' 0, 'opsz' 24;
}

.add-spot-pin-confirm {
  background: linear-gradient(180deg, var(--color-brand-navy-mid) 0%, var(--color-brand-navy) 100%);
  color: var(--color-on-primary);
  border-color: transparent;
}

.add-spot-pin-confirm:disabled {
  opacity: 0.38;
  cursor: not-allowed;
  transform: none;
  background: var(--color-surface-2);
  color: var(--color-text-sub);
}

/* ----- App Header -------------------------------------------------------- */
.app-header {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: var(--header-height);
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 14px;
  padding-top: var(--safe-top);
  background: var(--surface-header-ui);
  backdrop-filter: blur(18px);
  -webkit-backdrop-filter: blur(18px);
  box-shadow: var(--shadow-header);
  z-index: 100;
}

.hdr-left {
  display: flex;
  align-items: center;
  gap: 9px;
}

.hdr-brand-pin {
  flex-shrink: 0;
  display: block;
  filter: drop-shadow(0 2px 6px rgba(0, 0, 0, 0.2));
}

.hdr-name {
  font-family: var(--font-display);
  font-size: 16px;
  font-weight: var(--font-weight-display);
  letter-spacing: var(--letter-spacing-display);
  color: white;
  line-height: 1.2;
}

.hdr-profile-icon {
  font-size: 20px !important;
  color: white;
}

.filter-ms {
  font-size: 20px !important;
}

.hdr-loc {
  font-size: 11px;
  color: rgba(255, 255, 255, 0.5);
  margin-top: 1px;
}

.hdr-right {
  display: flex;
  align-items: center;
  gap: 8px;
}

.hdr-lang-toggle {
  min-width: var(--tap);
  min-height: 34px;
  padding: 0 12px;
  border-radius: var(--radius-button);
  background: rgba(255, 255, 255, 0.15);
  color: white;
  border: 1px solid rgba(255, 255, 255, 0.12);
  font-weight: var(--font-weight-medium);
  font-size: 12px;
  letter-spacing: var(--letter-spacing-label);
  transition: background-color var(--motion-base) var(--ease-standard);
}

.hdr-lang-toggle:active { background: rgba(255, 255, 255, 0.25); }

.btn-profile {
  width: 36px;
  height: 36px;
  border-radius: var(--radius-button);
  border: 1px solid rgba(255, 255, 255, 0.12);
  background: rgba(255, 255, 255, 0.1);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  transition: background-color var(--motion-base) var(--ease-standard);
}

.btn-profile:active { background: rgba(255, 255, 255, 0.22); }

.btn-profile:focus-visible {
  outline: 2px solid rgba(255, 255, 255, 0.6);
  outline-offset: 2px;
}

/* ----- Sheet nearby spots (SEO-SPOT-1 / UX-MF-6) ------------------------- */
.sheet-nearby-spots {
  padding: 12px 20px 20px;
  border-top: 1px solid var(--color-border);
}

.sheet-nearby-spots__title {
  margin: 0 0 8px;
  font-size: 13px;
  font-weight: 600;
  color: var(--color-text-sub);
}

.sheet-nearby-spots__list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
}

.sheet-nearby-spots__item {
  margin: 0;
}

.sheet-nearby-spots__link {
  display: flex;
  align-items: center;
  gap: 12px;
  min-height: 44px;
  padding: 6px 0;
  text-decoration: none;
  color: var(--color-text);
}

.sheet-nearby-spots__link:hover {
  color: var(--color-primary);
}

.sheet-nearby-spots__link:active {
  opacity: 0.85;
}

.sheet-nearby-spots__link:focus-visible {
  outline: var(--focus-outline);
  outline-offset: var(--focus-offset);
  border-radius: var(--radius-sm);
}

.sheet-nearby-spots__icon {
  flex-shrink: 0;
  width: 28px;
  height: 28px;
  border-radius: var(--radius-sm);
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.sheet-nearby-spots__icon--smoking {
  background: var(--color-cat-smoking-bg);
  color: var(--color-cat-smoking);
}

.sheet-nearby-spots__icon--trash {
  background: var(--color-cat-trash-bg);
  color: var(--color-cat-trash);
}

.sheet-nearby-spots__icon--toilet {
  background: var(--color-cat-toilet-bg);
  color: var(--color-cat-toilet);
}

.sheet-nearby-spots__ms {
  font-size: 20px !important;
  line-height: 1;
  font-variation-settings: 'FILL' 1, 'wght' 500, 'GRAD' 0, 'opsz' 24;
}

.sheet-nearby-spots__glyph {
  width: 20px;
  height: 20px;
  fill: currentColor;
}

.sheet-nearby-spots__name {
  font-size: 15px;
  font-weight: 600;
  line-height: 1.3;
  overflow: hidden;
  text-overflow: ellipsis;
}

/* ----- Home spot carousel (SEO-HOME-1 / UX-MF-16) ------------------------ */
.home-spot-carousel {
  position: absolute;
  top: calc(var(--header-height) + var(--safe-top));
  left: 0;
  right: 0;
  z-index: 95;
  box-sizing: border-box;
  display: flex;
  flex-direction: column;
  gap: 4px;
  padding: 6px 0 8px;
  background: var(--color-bg);
  border-bottom: 1px solid var(--color-brand-navy-tint);
  box-shadow: var(--shadow-1);
  pointer-events: auto;
}

.home-spot-carousel.is-collapsed {
  gap: 0;
  padding-bottom: 6px;
}

.home-spot-carousel__head {
  display: flex;
  align-items: center;
  gap: 4px;
  padding: 0 10px 0 14px;
  min-height: 24px;
  flex-shrink: 0;
  cursor: pointer;
  -webkit-tap-highlight-color: transparent;
}

.home-spot-carousel__toggle {
  flex-shrink: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 28px;
  height: 28px;
  margin: 0 0 0 auto;
  padding: 0;
  border: 0;
  border-radius: var(--radius-sm);
  background: transparent;
  color: var(--color-text-sub);
}

.home-spot-carousel__toggle:hover {
  color: var(--color-text);
}

.home-spot-carousel__toggle:focus-visible {
  outline: var(--focus-outline);
  outline-offset: var(--focus-offset);
}

.home-spot-carousel__toggle-icon {
  font-size: 20px !important;
  line-height: 1;
  font-variation-settings: 'FILL' 0, 'wght' 500, 'GRAD' 0, 'opsz' 24;
}

.home-spot-carousel__title {
  margin: 0;
  padding: 0;
  flex: 1;
  min-width: 0;
  font-size: 11px;
  font-weight: var(--font-weight-label);
  letter-spacing: var(--letter-spacing-label);
  text-transform: var(--text-transform-label);
  color: var(--color-text-sub);
  line-height: 1.2;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.home-spot-carousel.is-collapsed .home-spot-carousel__nav {
  display: none;
}

.home-spot-carousel__nav {
  flex: none;
  overflow: hidden;
}

.home-spot-carousel__list {
  display: flex;
  flex-direction: row;
  align-items: stretch;
  gap: 8px;
  margin: 0;
  padding: 0 12px 2px;
  list-style: none;
  overflow-x: auto;
  overflow-y: hidden;
  -webkit-overflow-scrolling: touch;
  scroll-snap-type: x proximity;
  scrollbar-width: thin;
}

.home-spot-carousel__item {
  flex: 0 0 auto;
  scroll-snap-align: start;
}

.home-spot-carousel__card {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  min-height: var(--tap);
  min-width: 44px;
  max-width: 220px;
  padding: 8px 12px;
  border-radius: var(--radius-card);
  background: var(--color-surface-elevated);
  border: none;
  box-shadow: var(--shadow-card);
  text-decoration: none;
  color: var(--color-text);
  transition: box-shadow var(--motion-fast) var(--ease-standard), transform var(--motion-fast) var(--ease-standard);
}

.home-spot-carousel__card:hover {
  box-shadow: var(--shadow-card);
}

.home-spot-carousel__card:active {
  transform: scale(0.98);
}

.home-spot-carousel__card:focus-visible {
  outline: var(--focus-outline);
  outline-offset: var(--focus-offset);
}

.home-spot-carousel__icon {
  flex-shrink: 0;
  width: 28px;
  height: 28px;
  border-radius: var(--radius-sm);
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.home-spot-carousel__icon--smoking {
  background: var(--color-cat-smoking-bg);
  color: var(--color-cat-smoking);
}

.home-spot-carousel__icon--trash {
  background: var(--color-cat-trash-bg);
  color: var(--color-cat-trash);
}

.home-spot-carousel__icon--toilet {
  background: var(--color-cat-toilet-bg);
  color: var(--color-cat-toilet);
}

.home-spot-carousel__ms {
  font-size: 20px !important;
  line-height: 1;
  font-variation-settings: 'FILL' 1, 'wght' 500, 'GRAD' 0, 'opsz' 24;
}

.home-spot-carousel__glyph {
  width: 20px;
  height: 20px;
  fill: currentColor;
}

.home-spot-carousel__name {
  font-size: 15px;
  font-weight: var(--font-weight-display);
  line-height: 1.25;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

@media (prefers-reduced-motion: reduce) {
  .home-spot-carousel__list {
    scroll-snap-type: none;
  }
}

body.add-spot-pin-mode #home-spot-carousel {
  display: none !important;
}

body.add-spot-pin-mode .map {
  padding-top: calc(var(--header-height) + var(--safe-top));
}

/* ----- Filter Bar (下部 / 親指ゾーン) ------------------------------------ */
/* 右は地図コントロール列と干渉しない余白（`right`）。縦位置は SCR-11 位置決定モードと同一（下端＋safe-area） */
.filter-bar {
  position: fixed;
  bottom: calc(var(--filter-bar-bottom) + var(--safe-bottom));
  left: 12px;
  right: 76px;
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: var(--filter-bar-stack-gap);
  z-index: 90;
  box-sizing: border-box;
}

.filter-bar-nav {
  display: flex;
  gap: 8px;
  width: 100%;
  min-width: 0;
  padding: 6px;
  border-radius: var(--radius-pill);
  background: var(--surface-header-ui);
  box-shadow: var(--shadow-elevated);
}

/* マイページ表示中は非表示（mypage.js が hidden 属性を付与） */
.filter-bar[hidden] {
  display: none !important;
}

/* ----- Sub-filter chip row ------------------------------------------------ */
.sub-filter-bar {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
  width: 100%;
  min-width: 0;
  box-sizing: border-box;
}

.sub-filter-bar[hidden] {
  display: none !important;
}

.sub-filter-chip {
  display: inline-flex;
  align-items: center;
  min-height: var(--tap);
  padding: 0 14px;
  border-radius: var(--radius-chip);
  border: none;
  background: var(--color-surface-elevated);
  color: var(--chip-color, var(--color-text-sub));
  font-size: 12px;
  font-weight: var(--font-weight-label);
  line-height: 1;
  cursor: pointer;
  box-shadow: var(--shadow-card);
  transition: background var(--motion-base) var(--ease-standard), color var(--motion-base) var(--ease-standard), box-shadow var(--motion-base) var(--ease-standard);
  white-space: nowrap;
  -webkit-tap-highlight-color: transparent;
}

.sub-filter-chip.is-active {
  background: var(--chip-color, var(--color-primary));
  color: var(--color-on-primary);
  border-color: transparent;
  box-shadow: var(--shadow-interactive);
}

body.add-spot-pin-mode .add-spot-pin-bar {
  bottom: calc(var(--filter-bar-stack-above-pin) + var(--safe-bottom));
}

/* SCR-11: 位置決定中は「現在営業中」・カテゴリ別メタのチップを隠し、ピン確認バーと重ならないようにする */
body.add-spot-pin-mode .open-now-bar,
body.add-spot-pin-mode #sub-filter-bar {
  display: none !important;
}

.filter-btn {
  flex: 1;
  min-height: var(--tap);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 4px;
  padding: 0 8px;
  border-radius: var(--radius-button);
  background: rgba(255, 255, 255, 0.06);
  color: rgba(255, 255, 255, 0.7);
  box-shadow: none;
  transition: background-color var(--motion-base) var(--ease-standard), color var(--motion-base) var(--ease-standard), box-shadow var(--motion-base) var(--ease-standard), transform var(--motion-fast) var(--ease-standard);
}

.filter-btn:active {
  transform: scale(0.96);
}

.filter-btn svg {
  flex-shrink: 0;
  display: block;
}

.filter-btn .flbl {
  font-size: 10px;
  font-weight: var(--font-weight-label);
  letter-spacing: var(--letter-spacing-label);
  text-transform: lowercase;
}

.filter-btn[data-category="smoking"] .om-cat-smoking-glyph,
.filter-btn[data-category="toilet"] .om-cat-toilet-glyph,
.filter-btn[data-category="trash"] .om-cat-trash-glyph {
  width: 1.5rem;
  height: 1.5rem;
  flex-shrink: 0;
  display: block;
  fill: currentColor;
}

/* アクティブ時 — カテゴリ淡色ピル＋前景 CUD 色 */
.filter-btn.is-active {
  box-shadow: var(--shadow-card);
}
.filter-btn.is-active[data-category="all"] {
  background: rgba(255, 255, 255, 0.92);
  color: var(--color-brand-navy);
}
.filter-btn.is-active[data-category="smoking"] {
  background: var(--color-cat-smoking-bg);
  color: var(--color-cat-smoking);
}
.filter-btn.is-active[data-category="trash"] {
  background: var(--color-cat-trash-bg);
  color: var(--color-cat-trash);
}
.filter-btn.is-active[data-category="toilet"] {
  background: var(--color-cat-toilet-bg);
  color: var(--color-cat-toilet);
}

/* ----- 投稿 FAB（中央）／地図コントロール（右下スタック）------------------- */
.map-controls-stack {
  position: fixed;
  right: 16px;
  bottom: calc(24px + var(--safe-bottom));
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 10px;
  z-index: 11;
}

.map-controls-stack .map-ctrl-btn {
  margin: 0;
}

.map-ctrl-btn {
  width: 48px;
  height: 48px;
  border-radius: 50%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: var(--color-surface-elevated);
  color: var(--color-text-sub);
  border: none;
  box-shadow: var(--shadow-card);
  transition: transform var(--motion-fast) var(--ease-standard), background-color var(--motion-base) var(--ease-standard), box-shadow var(--motion-base) var(--ease-standard);
}

#add-spot-btn {
  background: var(--btn-primary-bg);
  color: var(--btn-primary-color);
  border-color: transparent;
  box-shadow: var(--btn-primary-shadow);
}

#add-spot-btn .material-symbols-rounded {
  color: var(--btn-primary-color);
}

#add-spot-btn:active {
  background: var(--btn-primary-bg-hover);
  box-shadow: var(--btn-primary-shadow-hover);
}

#add-spot-btn:focus-visible {
  outline: 3px solid var(--btn-primary-bg);
  outline-offset: 2px;
}

.map-ctrl-btn .material-symbols-rounded {
  font-size: 22px;
  font-variation-settings: 'FILL' 1, 'wght' 500, 'GRAD' 0, 'opsz' 24;
  color: var(--color-brand-navy);
}

.map-ctrl-btn:active {
  transform: scale(0.94);
}

.map-ctrl-btn:focus-visible {
  outline: 3px solid var(--color-primary);
  outline-offset: 2px;
}

/* ----- Language toggle (ヘッダー内) -------------------------------------- */
/* スタンドアロン .lang-toggle は廃止。.hdr-lang-toggle を使用する。 */

/* 2ボタン式セグメントコントロール（JA / EN）*/
.hdr-lang-switcher {
  display: inline-flex;
  align-items: center;
  gap: 2px;
  background: rgba(255, 255, 255, 0.12);
  border: 1px solid rgba(255, 255, 255, 0.22);
  border-radius: var(--radius-pill);
  padding: 3px;
}

.lang-btn {
  min-width: var(--tap-min);
  min-height: var(--tap-min);
  padding: 0 12px;
  border-radius: var(--radius-pill);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.06em;
  color: rgba(255, 255, 255, 0.55);
  background: transparent;
  transition:
    background-color var(--motion-base) var(--ease-standard),
    color var(--motion-base) var(--ease-standard);
}

.lang-btn.is-active {
  background: rgba(255, 255, 255, 0.92);
  color: var(--color-header);
}

.lang-btn:hover:not(.is-active) {
  color: rgba(255, 255, 255, 0.8);
}

.lang-btn:focus-visible {
  outline: 2px solid rgba(255, 255, 255, 0.6);
  outline-offset: 1px;
}

/* ----- Bottom Sheet ------------------------------------------------------ */
.sheet {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 20;
  background: var(--color-bg);
  border-top-left-radius: var(--radius-lg);
  border-top-right-radius: var(--radius-lg);
  box-shadow: 0 -4px 16px rgba(0, 0, 0, 0.14);
  transform: translateY(100%);
  transition: transform 240ms cubic-bezier(0.2, 0.8, 0.2, 1);
  max-height: 70vh;
  display: flex;
  flex-direction: column;
  padding-bottom: var(--safe-bottom);
}

.sheet.is-open {
  transform: translateY(0);
}

/* スポット詳細シート表示中: 地図側タップで閉じる（ヘッダ z-index より下・シートより上） */
.sheet-backdrop {
  position: fixed;
  inset: 0;
  z-index: 15;
  margin: 0;
  padding: 0;
  border: 0;
  display: block;
  width: 100%;
  height: 100%;
  background: var(--color-overlay);
  cursor: pointer;
  -webkit-tap-highlight-color: transparent;
}

.sheet-handle {
  width: 44px;
  height: 5px;
  border-radius: var(--radius-pill);
  background: var(--color-border);
  margin: 10px auto 6px;
  cursor: grab;
}

.sheet-header {
  padding: 8px 20px 12px;
  border-bottom: 1px solid var(--color-border);
  display: flex;
  flex-direction: column;
  align-items: flex-start;
}

/* シートタイトル行（Marketing 提案 §9.1）
   カテゴリピクトグラム + タイトル + タグ */
.sheet-title-row {
  display: flex;
  align-items: center;
  gap: 10px;
  align-self: stretch;
}

.sheet-registered-by {
  margin: 4px 0 0;
  font-size: 12px;
  color: var(--color-text-sub);
}

/* カテゴリ・メタ情報ピル（タイトル下・左寄せ・同一行〜折返し） */
.sheet-meta-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-top: 6px;
  justify-content: flex-start;
  align-items: center;
}

/* トイレは涙型ピンの先端が 28px 枠より下に出るため、他カテゴリ（円・角丸）と同程度の見た目間隔になるよう余白を追加 */
#sheet-meta-tags[data-sheet-category="toilet"] {
  margin-top: 12px;
}

.sheet-meta-extras {
  display: inline-flex;
  flex-wrap: wrap;
  gap: 6px;
  align-items: center;
}


.sheet-cat-dot {
  flex: 0 0 auto;
  width: 28px;
  height: 28px;
  border-radius: 50%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--color-on-primary);
  background: var(--color-text-sub);
}

.sheet-cat-dot[data-category="smoking"] { background: var(--color-cat-smoking); border-radius: 50%; }
.sheet-cat-dot[data-category="trash"]   { background: var(--color-cat-trash);   border-radius: var(--radius-sm); }
.sheet-cat-dot[data-category="toilet"]  { background: var(--color-cat-toilet);  border-radius: 50% 50% 50% 0; transform: rotate(-45deg); }
.sheet-cat-dot[data-category="toilet"] svg { transform: rotate(45deg); }
.sheet-cat-dot svg {
  width: 16px;
  height: 16px;
  fill: currentColor;
}

/* 喫煙（・マップ上のマーカーと同一グリフ） */
.sheet-cat-dot .sheet-cat-dot__ms {
  font-size: 16px;
  line-height: 1;
  color: var(--color-on-primary);
  font-variation-settings: "FILL" 1, "wght" 500, "GRAD" 0, "opsz" 24;
  user-select: none;
}

.sheet-title {
  margin: 0;
  font-size: 18px;
  font-weight: var(--font-weight-display);
  letter-spacing: var(--letter-spacing-display);
  line-height: 1.3;
  flex: 1 1 auto;
  min-width: 0;
}

/* 詳細シートのカテゴリ／メタは同一ピル寸法・字重で統一 */
.sheet-category,
.sheet-meta-extra {
  display: inline-block;
  margin: 0;
  padding: 2px 10px;
  font-size: 12px;
  line-height: 1.35;
  border-radius: var(--radius-pill);
  font-weight: 500;
  vertical-align: middle;
}

.sheet-category {
  background: var(--color-surface);
  color: var(--color-text-sub);
}

.sheet-meta-extra {
  background: var(--color-surface);
  color: var(--color-text-sub);
}

/* カテゴリタグ背景: Marketing 提案 §7.2 の bg トークン */
.sheet-category[data-category="smoking"] { background: var(--color-cat-smoking-bg); color: var(--color-cat-smoking); }
.sheet-category[data-category="trash"]   { background: var(--color-cat-trash-bg);   color: var(--color-cat-trash); }
.sheet-category[data-category="toilet"]  { background: var(--color-cat-toilet-bg);  color: var(--color-cat-toilet); }

#sheet-meta-tags[data-sheet-category="smoking"] .sheet-meta-extra {
  background: var(--color-cat-smoking-bg);
  color: var(--color-cat-smoking);
}
#sheet-meta-tags[data-sheet-category="trash"] .sheet-meta-extra {
  background: var(--color-cat-trash-bg);
  color: var(--color-cat-trash);
}
#sheet-meta-tags[data-sheet-category="toilet"] .sheet-meta-extra {
  background: var(--color-cat-toilet-bg);
  color: var(--color-cat-toilet);
}

/* ギャラリーとコメントをひと続きで縦スクロール（CTA は下端固定） */
.sheet-scroll {
  flex: 1 1 auto;
  min-height: 0;
  overflow-x: hidden;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
}

.sheet-comments {
  padding: 12px 20px 20px;
}

.comment {
  padding: 12px 0;
  border-bottom: 1px solid var(--color-border);
}

.comment:last-child { border-bottom: 0; }

[data-optimistic="true"] { opacity: 0.7; pointer-events: none; }

.comment-meta {
  display: flex;
  align-items: center;
  justify-content: space-between;
  font-size: 12px;
  color: var(--color-text-sub);
  margin-bottom: 6px;
  gap: 8px;
}

.comment-meta-left {
  display: inline-flex;
  align-items: center;
  gap: 6px;
}

.comment-author {
  font-weight: 600;
  color: var(--color-text);
}

.comment-date {
  color: var(--color-text-sub);
}

.comment-text {
  margin: 0;
  font-size: 15px;
  line-height: 1.55;
}

.comment--has-photo .comment-photofigure {
  margin: 0 0 8px;
}

.comment-photofigure {
  margin: 0;
}

.comment-photo {
  display: block;
  width: 100%;
  max-height: min(26vh, 168px);
  object-fit: cover;
  border-radius: var(--radius-md, 12px);
  background: var(--color-surface);
}

.comment--photo-only .comment-photo {
  max-height: min(30vh, 192px);
}

.comment-photo-caption {
  margin: 6px 0 0;
  font-size: 12px;
  color: var(--color-text-sub);
  font-weight: 500;
}

.mypage-post-thumb {
  display: block;
  width: 100%;
  height: 100%;
  max-height: 140px;
  object-fit: cover;
}

.comment-actions {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px;
  margin-top: 8px;
}

.comment-action {
  min-width: var(--tap-min);
  min-height: var(--tap-min);
  padding: 6px 10px;
  font-size: 13px;
  border-radius: var(--radius-pill);
  background: var(--color-surface);
  color: var(--color-text-sub);
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.comment-action-ic {
  font-size: 20px !important;
  font-variation-settings: 'FILL' 0;
  line-height: 1;
}

.comment-action .comment-thanks-action-ic {
  font-size: 20px !important;
}

.comment-action.js-thanks {
  gap: 5px;
  padding: 6px 12px;
}

.comment-action.js-thanks .comment-thanks-count-num {
  font-weight: 600;
  font-variant-numeric: tabular-nums;
  line-height: 1;
}

.comment-action--danger .comment-action-ic {
  color: var(--color-danger);
}

/* 自分のコメントのみ: 削除はアイコン寸法の正方形・行末へ */
.comment-actions > .comment-action--danger:only-child {
  margin-left: auto;
  flex-shrink: 0;
  width: var(--tap);
  height: var(--tap);
  min-width: var(--tap);
  min-height: var(--tap);
  padding: 0;
  border-radius: var(--radius-md);
}

.comment-action.is-active {
  background: var(--color-warm);
  color: var(--color-on-primary);
}

.comment-action.is-thanked {
  background: var(--color-warm-soft);
  color: var(--color-warm-dark);
}
.comment-action.is-thanked .comment-thanks-action-ic {
  color: var(--color-warm-dark);
  font-variation-settings: 'FILL' 1;
}
.comment-action.is-thanked .comment-thanks-count-num {
  color: var(--color-warm-dark);
}

.sheet-empty {
  text-align: center;
  color: var(--color-text-sub);
  padding: 40px 0;
  font-size: 14px;
}

/* シート内 CTA（このスポットに投稿）— sheet が FAB を覆うため、シート内に常設 */
.sheet-cta {
  flex: 0 0 auto;
  padding: 10px 16px 14px;
  border-top: 1px solid var(--color-border);
  background: var(--color-bg);
}

.sheet-cta-btn {
  width: 100%;
  min-height: 48px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 10px 16px;
  border-radius: var(--radius-button);
  background: var(--color-action);
  color: #FFFFFF;
  font-size: 16px;
  font-weight: var(--font-weight-button);
  box-shadow: var(--shadow-fab);
  transition: background-color var(--motion-base) var(--ease-standard), box-shadow var(--motion-base) var(--ease-standard), transform var(--motion-fast) var(--ease-standard);
}

.sheet-cta-btn:hover {
  background: var(--color-action-hover);
  color: #FFFFFF;
  box-shadow: var(--shadow-fab-hover);
}
.sheet-cta-btn:active { transform: scale(0.98); }

.sheet-cta-btn .sheet-cta-icon {
  font-size: 22px;
  line-height: 1;
  color: #FFFFFF;
}

.sheet-cta-label { font-size: 15px; }

.sheet-cta-actions {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.sheet-cta-btn--secondary {
  text-decoration: none;
  box-sizing: border-box;
  background: var(--color-action-soft);
  color: var(--color-action);
  border: none;
  box-shadow: var(--shadow-1);
  font-weight: var(--font-weight-button);
  cursor: pointer;
  text-align: center;
  -webkit-tap-highlight-color: transparent;
}

.sheet-cta-btn--secondary:hover {
  background: var(--color-action-soft);
  color: var(--color-action-hover);
}

.sheet-cta-btn--secondary .sheet-cta-icon {
  color: var(--color-action);
}

/* ----- 最近追加スポット（右ドロワー）---------------------------------------- */
.map-ctrl-btn--recent {
  position: relative;
}

.recent-drawer-badge {
  position: absolute;
  top: 1px;
  right: 1px;
  min-width: 18px;
  height: 18px;
  padding: 0 4px;
  border-radius: 999px;
  background: var(--color-danger);
  color: var(--color-on-primary);
  font-size: 10px;
  font-weight: 700;
  line-height: 18px;
  text-align: center;
  pointer-events: none;
  box-shadow: var(--shadow-badge);
}

.recent-drawer-backdrop {
  position: fixed;
  inset: 0;
  z-index: 90;
  background: var(--color-overlay-backdrop);
  -webkit-tap-highlight-color: transparent;
}

.recent-drawer-panel {
  position: fixed;
  top: 0;
  right: 0;
  bottom: 0;
  z-index: 95;
  width: min(360px, 90vw);
  max-width: 100%;
  background: var(--color-surface-drawer);
  box-shadow: var(--shadow-drawer-emphasis);
  border-left: 1px solid var(--color-border-brand);
  display: flex;
  flex-direction: column;
  padding-top: calc(var(--header-height) + var(--safe-top));
  padding-bottom: var(--safe-bottom);
}

.recent-drawer-inner {
  display: flex;
  flex-direction: column;
  min-height: 0;
  flex: 1;
  padding: 12px 14px 16px;
}

.recent-drawer-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  margin-bottom: 12px;
}

.recent-drawer-title {
  margin: 0;
  flex: 1;
  min-width: 0;
  font-family: var(--font-display);
  font-size: 17px;
  font-weight: var(--font-weight-display);
  letter-spacing: var(--letter-spacing-display);
  color: var(--color-header);
}

.recent-drawer-close {
  width: 40px;
  height: 40px;
  border-radius: 50%;
  border: 1px solid rgba(0, 0, 0, 0.1);
  background: var(--color-surface-elevated);
  color: var(--color-text-sub);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  flex-shrink: 0;
}

.recent-drawer-close .material-symbols-rounded {
  font-size: 22px;
}

.recent-drawer-close:focus-visible {
  outline: 3px solid var(--color-primary);
  outline-offset: 2px;
}

.recent-drawer-radius {
  border: 0;
  margin: 0 0 14px;
  padding: 0;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 6px;
  align-items: stretch;
}

.recent-drawer-radio {
  position: relative;
  min-width: 0;
  margin: 0;
  cursor: pointer;
}

.recent-drawer-radio input {
  position: absolute;
  opacity: 0;
  width: 1px;
  height: 1px;
  margin: 0;
  pointer-events: none;
}

.recent-drawer-radio-chip {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 44px;
  box-sizing: border-box;
  padding: 8px 6px;
  border-radius: var(--radius-pill);
  border: 1.5px solid var(--color-border-emphasis);
  background: var(--color-surface-elevated);
  color: var(--color-text);
  font-size: 12px;
  font-weight: 600;
  line-height: 1.25;
  text-align: center;
  transition:
    background-color var(--motion-base) var(--ease-standard),
    border-color var(--motion-base) var(--ease-standard),
    color var(--motion-base) var(--ease-standard),
    box-shadow var(--motion-base) var(--ease-standard);
}

.recent-drawer-radio-chip > span {
  display: block;
  max-width: 100%;
  word-break: break-word;
}

.recent-drawer-radio input:checked + .recent-drawer-radio-chip {
  background: var(--color-primary);
  border-color: var(--color-primary);
  color: var(--color-on-primary);
  box-shadow: var(--shadow-chip-selected);
}

.recent-drawer-radio input:focus-visible + .recent-drawer-radio-chip {
  outline: var(--focus-outline-accent);
  outline-offset: var(--focus-offset);
}

.recent-drawer-radio:has(input:disabled) {
  cursor: not-allowed;
}

.recent-drawer-radio:has(input:disabled) .recent-drawer-radio-chip {
  opacity: 0.48;
}

.recent-drawer-radius-hint {
  grid-column: 1 / -1;
  margin: 4px 0 0;
  font-size: 12px;
  line-height: 1.45;
  color: var(--color-text-sub);
}

.recent-drawer-list {
  flex: 1;
  min-height: 120px;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.recent-drawer-empty {
  margin: 24px 0;
  text-align: center;
  font-size: 14px;
  color: var(--color-text-sub);
  line-height: 1.5;
}

.recent-drawer-card {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 4px;
  padding: 12px 12px 10px;
  border-radius: var(--radius-card);
  background: var(--color-surface-elevated);
  border: none;
  box-shadow: var(--shadow-card);
  text-decoration: none;
  color: inherit;
  transition: box-shadow var(--motion-base) var(--ease-standard), transform var(--motion-fast) var(--ease-standard);
}

.recent-drawer-card:hover {
  box-shadow: var(--shadow-2);
}

.recent-drawer-card:active {
  transform: scale(0.98);
}

.recent-drawer-card:focus-visible {
  outline: 3px solid var(--color-primary);
  outline-offset: 2px;
}

.recent-drawer-card__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  gap: 8px;
}

.recent-drawer-card__new {
  font-size: 22px;
  line-height: 1;
  color: var(--color-danger);
  font-variation-settings: 'FILL' 1, 'wght' 600, 'GRAD' 0, 'opsz' 24;
  flex-shrink: 0;
  pointer-events: none;
}

.recent-drawer-card__cat {
  font-size: 11px;
  font-weight: var(--font-weight-label);
  letter-spacing: var(--letter-spacing-label);
  text-transform: var(--text-transform-label);
  color: var(--color-text-sub);
}

.recent-drawer-card__name {
  font-size: 15px;
  font-weight: var(--font-weight-display);
  color: var(--color-text);
  line-height: 1.35;
  word-break: break-word;
}

.recent-drawer-card__dist {
  font-size: 13px;
  font-weight: 600;
  color: var(--color-text-sub);
}

.recent-drawer-card__time {
  font-size: 12px;
  color: var(--color-text-sub);
}

body.add-spot-pin-mode #recent-drawer-toggle,
body.add-spot-pin-mode #recent-drawer-panel,
body.add-spot-pin-mode #recent-drawer-backdrop {
  display: none !important;
}

/* バッジ（Marketing 提案 §4.3 軽量版） */
.badge {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 1px 8px;
  font-size: 11px;
  font-weight: 600;
  border-radius: var(--radius-pill);
  background: var(--color-surface);
  color: var(--color-text-sub);
  line-height: 1.4;
}

.badge--welcomer { background: #E5F4EA; color: #1B8E5A; }
.badge--guide    { background: var(--color-cat-toilet-bg); color: var(--color-cat-toilet); }
.badge--star     { background: var(--color-warm-soft); color: var(--color-warm-dark); }
.badge--hero     { background: #F8E5DF; color: #9A3F2A; }

/* ----- Modal (post) ----------------------------------------------------- */
.modal {
  position: fixed;
  inset: 0;
  z-index: 200;
  display: flex;
  align-items: flex-end;
  justify-content: center;
  pointer-events: none;
}

.modal[aria-hidden="false"] {
  pointer-events: auto;
}

.modal-backdrop {
  position: absolute;
  inset: 0;
  background: var(--color-overlay);
  opacity: 0;
  transition: opacity 200ms ease;
}

.modal[aria-hidden="false"] .modal-backdrop {
  opacity: 1;
}

.modal-panel {
  position: relative;
  width: 100%;
  max-width: 480px;
  background: var(--color-bg);
  border-top-left-radius: var(--radius-modal-top);
  border-top-right-radius: var(--radius-modal-top);
  padding: 16px 20px calc(16px + var(--safe-bottom));
  box-shadow: var(--shadow-modal-sheet);
  transform: translateY(100%);
  transition: transform 240ms cubic-bezier(0.2, 0.8, 0.2, 1);
}

.modal[aria-hidden="false"] .modal-panel {
  transform: translateY(0);
}

.modal-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 4px;
}

.modal-title {
  margin: 0;
  font-size: 17px;
  font-weight: var(--font-weight-display);
  letter-spacing: var(--letter-spacing-display);
}

.modal-subcopy {
  margin: 0 0 8px;
  font-size: 12px;
  color: var(--color-text-sub);
  font-weight: 500;
}

.modal-close {
  width: var(--tap);
  height: var(--tap);
  border-radius: 50%;
  font-size: 22px;
  color: var(--color-text-sub);
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.modal-close-icon {
  font-size: 24px !important;
  color: var(--color-text-sub);
}

.modal-context {
  margin: 0 0 12px;
  font-size: 13px;
  color: var(--color-text-sub);
  min-height: 18px;
}

.modal-context.is-targeted {
  padding: 8px 12px;
  border-radius: var(--radius-md);
  background: var(--color-surface);
  color: var(--color-text);
  border-left: 3px solid var(--color-accent);
}

.modal-context.is-targeted strong { font-weight: 700; }

.modal-form {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.modal-label {
  font-size: 12px;
  font-weight: var(--font-weight-label);
  letter-spacing: var(--letter-spacing-label);
  text-transform: var(--text-transform-label);
  color: var(--color-text-sub);
}

.modal-input {
  font: inherit;
  width: 100%;
  border: 1px solid var(--input-border);
  border-radius: var(--input-radius);
  padding: 10px 12px;
  background: var(--input-bg);
  color: var(--color-text);
  min-height: var(--tap);
  box-shadow: var(--input-shadow);
  transition: border-color var(--motion-base) var(--ease-standard), box-shadow var(--motion-base) var(--ease-standard);
}

.modal-input:focus {
  outline: none;
  border-color: var(--input-border-focus);
  box-shadow: var(--input-shadow-focus);
}

.modal-textarea {
  font: inherit;
  width: 100%;
  border: 1px solid var(--input-border);
  border-radius: var(--input-radius);
  padding: 10px 12px;
  resize: vertical;
  min-height: 96px;
  background: var(--input-bg);
  color: var(--color-text);
  box-shadow: var(--input-shadow);
  transition: border-color var(--motion-base) var(--ease-standard), box-shadow var(--motion-base) var(--ease-standard);
}

.modal-textarea:focus {
  outline: none;
  border-color: var(--input-border-focus);
  box-shadow: var(--input-shadow-focus);
}

.modal-meta {
  display: flex;
  justify-content: flex-end;
}

.modal-counter {
  font-size: 12px;
  color: var(--color-success);
  font-weight: 500;
}

.modal-counter.is-warn {
  color: var(--color-warning);
}

.modal-counter.is-over {
  color: var(--color-danger);
}

.modal-photo-row {
  display: flex;
  flex-direction: column;
  gap: 6px;
  margin-top: 10px;
}

.modal-photo-controls {
  display: flex;
  align-items: center;
  gap: 8px;
}

.modal-photo-btn {
  display: inline-flex;
  align-items: center;
  min-height: var(--tap);
  padding: 0 14px;
  border-radius: var(--radius-button);
  font-size: 14px;
  font-weight: var(--font-weight-button);
  background: var(--color-surface);
  color: var(--color-text);
  cursor: pointer;
  border: none;
  box-shadow: var(--shadow-1);
}

.modal-photo-input {
  display: none;
}

.modal-photo-remove {
  min-height: var(--tap);
  padding: 0 12px;
  border-radius: var(--radius-pill);
  font-size: 13px;
  font-weight: 500;
  background: transparent;
  color: var(--color-danger);
  border: 1px solid var(--color-danger);
  cursor: pointer;
}

.modal-photo-preview {
  width: 100%;
  max-height: 160px;
  overflow: hidden;
  border-radius: var(--radius-md, 8px);
  background: var(--color-surface);
}

.modal-photo-preview img {
  width: 100%;
  height: 160px;
  object-fit: cover;
  display: block;
}

.modal-actions {
  display: flex;
  gap: 10px;
  justify-content: flex-end;
  margin-top: 6px;
}

.modal-btn {
  min-height: var(--tap);
  padding: 0 18px;
  border-radius: var(--radius-button);
  font-size: 15px;
  font-weight: var(--font-weight-button);
}

.modal-btn-secondary {
  background: var(--color-surface);
  color: var(--color-text);
}

.modal-btn-primary {
  background: var(--color-action);
  color: var(--btn-primary-color);
  border-radius: var(--radius-button);
}

.modal-btn-primary:hover {
  background: var(--color-action-hover);
}

.modal-btn-primary:disabled {
  opacity: 0.55;
  cursor: not-allowed;
}

/* ----- Post modal（投稿フォーム）— M3 風・おもてなしトーン ------------------ */
#post-modal .modal-panel--post {
  background: var(--color-bg);
  border-top-left-radius: var(--radius-modal-top);
  border-top-right-radius: var(--radius-modal-top);
  box-shadow: var(--shadow-modal-sheet);
  padding: 18px 20px calc(18px + var(--safe-bottom));
}

#post-modal .modal-title--post {
  font-family: var(--font-display);
  font-size: 1.4rem;
  font-weight: var(--font-weight-display);
  letter-spacing: var(--letter-spacing-display);
  color: var(--color-primary);
}

#post-modal .modal-subcopy--post {
  font-family: var(--font-display);
  font-size: 0.8125rem;
  line-height: 1.45;
  margin-bottom: 10px;
}

#post-modal .modal-form--post {
  gap: 12px;
}

#post-modal .modal-post-hint {
  margin: -4px 0 4px;
  font-size: 13px;
  line-height: 1.45;
  color: var(--color-text-sub);
}

#post-modal .modal-context.is-targeted {
  background: rgba(255, 255, 255, 0.85);
  border-left-color: var(--color-accent);
}

.post-cat-fieldset {
  border: 0;
  padding: 0;
  margin: 0 0 4px;
}

.post-cat-legend {
  font-size: 0.75rem;
  font-weight: var(--font-weight-label);
  letter-spacing: var(--letter-spacing-label);
  text-transform: var(--text-transform-label);
  color: var(--color-text-sub);
  margin: 0 0 8px;
  padding: 0;
}

.post-cat-row {
  display: flex;
  gap: 8px;
}

.post-cat-opt {
  position: relative;
  flex: 1 1 0;
  min-width: 0;
}

.post-cat-opt input {
  position: absolute;
  opacity: 0;
  width: 1px;
  height: 1px;
  pointer-events: none;
}

.post-cat-chip,
.addspot-cat-chip {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 6px;
  min-height: 88px;
  padding: 12px 8px;
  border: none;
  border-radius: var(--radius-chip);
  background: var(--color-surface-elevated);
  color: var(--color-text);
  font-size: 0.75rem;
  font-weight: var(--font-weight-label);
  line-height: 1.2;
  text-align: center;
  cursor: pointer;
  box-shadow: var(--shadow-card);
  transition: background-color var(--motion-base) var(--ease-standard), color var(--motion-base) var(--ease-standard), box-shadow var(--motion-base) var(--ease-standard);
}

.post-cat-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--color-text-sub);
  transition: color var(--motion-base) var(--ease-standard);
}

.post-cat-icon .om-cat-smoking-glyph,
.post-cat-icon .om-cat-trash-glyph,
.post-cat-icon .om-cat-toilet-glyph {
  width: 1.875rem;
  height: 1.875rem;
  display: block;
  fill: currentColor;
}

.post-cat-label {
  display: block;
  max-width: 100%;
  overflow: hidden;
  text-overflow: ellipsis;
}

.post-cat-opt input:checked + .post-cat-chip {
  background: var(--color-primary);
  color: var(--color-on-primary);
  box-shadow: var(--shadow-interactive);
}

.post-cat-opt input:checked + .post-cat-chip .post-cat-icon {
  color: var(--color-on-primary);
}

.post-cat-opt input:focus-visible + .post-cat-chip {
  outline: var(--focus-outline-accent);
  outline-offset: var(--focus-offset);
}

#post-modal .modal-textarea--post {
  border: 1px solid var(--input-border);
  border-radius: var(--input-radius);
  background: var(--input-bg);
  line-height: 1.5;
  box-shadow: var(--input-shadow);
  transition: border-color var(--motion-base) var(--ease-standard), box-shadow var(--motion-base) var(--ease-standard);
}

#post-modal .modal-textarea--post:focus {
  outline: none;
  border-color: var(--input-border-focus);
  box-shadow: var(--input-shadow-focus);
}

#post-modal .post-comment-label {
  margin-top: 4px;
}

.modal-anonymous-label {
  display: flex;
  align-items: center;
  gap: 8px;
  min-height: var(--tap);
  padding: 4px 0;
  cursor: pointer;
  font-size: 13px;
  color: var(--color-text-sub);
  user-select: none;
}

.modal-anonymous-check {
  flex-shrink: 0;
  width: 20px;
  height: 20px;
  margin: 0;
  accent-color: var(--color-accent);
  cursor: pointer;
}

.modal-actions--post {
  justify-content: space-between;
  align-items: center;
  margin-top: 8px;
  gap: 12px;
}

#post-modal .modal-btn-text {
  min-height: var(--tap);
  padding: 0 8px;
  border: none;
  background: none;
  font: inherit;
  font-size: 0.875rem;
  font-weight: 500;
  color: var(--color-text-sub);
  cursor: pointer;
  text-decoration: none;
  border-radius: 8px;
}

#post-modal .modal-btn-text:hover {
  color: var(--color-text);
}

#post-modal .modal-btn-text:focus-visible {
  outline: var(--focus-outline-accent);
  outline-offset: var(--focus-offset);
}

#post-modal #post-modal .modal-btn-post-submit {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  min-height: var(--tap);
  padding: 0 22px 0 20px;
  border: none;
  border-radius: var(--radius-button);
  font-family: inherit;
  font-size: 0.9375rem;
  font-weight: var(--font-weight-button);
  letter-spacing: var(--letter-spacing-label);
  background: var(--color-action);
  color: var(--btn-primary-color);
  cursor: pointer;
  box-shadow: var(--shadow-fab);
  transition: background-color var(--motion-base) var(--ease-standard), box-shadow var(--motion-base) var(--ease-standard), opacity var(--motion-base) var(--ease-standard);
}

#post-modal .modal-btn-post-submit:hover {
  background: var(--color-action-hover);
  box-shadow: var(--shadow-fab-hover);
}

#post-modal .modal-btn-post-submit:focus-visible {
  outline: var(--focus-outline);
  outline-offset: var(--focus-offset);
}

#post-modal .modal-btn-post-submit:disabled {
  opacity: 0.55;
  cursor: not-allowed;
  box-shadow: none;
}

#post-modal #post-modal .modal-btn-post-icon {
  font-size: 1.25rem !important;
  margin-right: -2px;
}

.post-modal-footnote {
  margin: 4px 0 0;
  font-size: 0.6875rem;
  line-height: 1.45;
  color: var(--color-text-sub);
  text-align: center;
}

@media (min-width: 768px) {
  #post-modal .modal-panel--post,
  #add-spot-modal .modal-panel--addspot {
    border-radius: 24px;
  }

  .modal {
    align-items: center;
  }
  .modal-panel {
    border-radius: var(--radius-lg);
    transform: translateY(20px);
  }
  .modal[aria-hidden="false"] .modal-panel {
    transform: translateY(0);
  }
}

/* ----- Add Spot Modal (F-14) — 投稿モーダルと同系のおもてなしトーン ------------ */
#add-spot-modal .modal-panel--addspot {
  background: var(--color-bg);
  border-top-left-radius: var(--radius-modal-top);
  border-top-right-radius: var(--radius-modal-top);
  box-shadow: var(--shadow-modal-sheet);
  padding: 18px 20px calc(18px + var(--safe-bottom));
  /* 長いフォーム（営業時間 7 行など）でビューポートより高くなり上端が欠けるのを防ぐ（F-14 スポット追加） */
  max-height: calc(100vh - var(--safe-top) - 8px);
  max-height: calc(100dvh - var(--safe-top) - 8px);
  overflow-x: hidden;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
  overscroll-behavior-y: contain;
}

#add-spot-modal .modal-title--addspot {
  font-family: var(--font-display);
  font-size: 1.4rem;
  font-weight: var(--font-weight-display);
  letter-spacing: var(--letter-spacing-display);
  color: var(--color-primary);
}

#add-spot-modal .modal-subcopy--addspot {
  font-family: var(--font-display);
  font-size: 0.8125rem;
  line-height: 1.45;
  margin-bottom: 8px;
  color: var(--color-text-sub);
}

#add-spot-modal .modal-context--addspot {
  font-size: 0.8125rem;
  line-height: 1.45;
  color: var(--color-text-sub);
  margin-bottom: 12px;
}

.modal-form--addspot {
  gap: 14px;
}

/* メタ情報 fieldset: UA の legend オフセットを打ち消し、ラベル・チップを「場所の名前」と同じ左軸に揃える */
#add-spot-modal .addspot-smoking-type-group,
#add-spot-modal .addspot-trash-types-group,
#add-spot-modal .addspot-attrs-group {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  min-width: 0;
}

#add-spot-modal .addspot-smoking-type-group > legend.modal-label,
#add-spot-modal .addspot-trash-types-group > legend.modal-label,
#add-spot-modal .addspot-attrs-group > legend.modal-label {
  float: none;
  position: static;
  display: block;
  width: 100%;
  max-width: 100%;
  box-sizing: border-box;
  margin: 0 0 8px;
  padding: 0;
}

#add-spot-modal .addspot-smoking-type-row,
#add-spot-modal .addspot-trash-row,
#add-spot-modal .addspot-attrs-row {
  width: 100%;
  max-width: 100%;
}

/* スポット情報更新: メタ fieldset も legend を名前入力と同じ左軸に（UA 既定の legend オフセット解消） */
#spot-meta-modal .spot-meta-fieldset {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  min-width: 0;
}

#spot-meta-modal .spot-meta-fieldset > legend.modal-label {
  float: none;
  position: static;
  display: block;
  width: 100%;
  max-width: 100%;
  box-sizing: border-box;
  margin: 0 0 8px;
  padding: 0;
}

#spot-meta-modal .addspot-smoking-type-row,
#spot-meta-modal .addspot-trash-row,
#spot-meta-modal .addspot-attrs-row {
  width: 100%;
  max-width: 100%;
  min-height: calc(38px + 8px + 38px);
  align-content: flex-start;
}

.modal-actions--addspot {
  margin-top: 8px;
}

.modal-input--addspot {
  background: var(--input-bg);
  border-radius: var(--input-radius);
  border: 1px solid var(--input-border);
  box-shadow: var(--input-shadow);
}

.addspot-fieldset {
  border: 0;
  padding: 0;
  margin: 0 0 2px;
}

.addspot-legend {
  font-size: 0.75rem;
  font-weight: var(--font-weight-label);
  letter-spacing: var(--letter-spacing-label);
  text-transform: var(--text-transform-label);
  color: var(--color-text-sub);
  margin: 0 0 10px;
  padding: 0;
}

.addspot-cat-row {
  display: flex;
  gap: 10px;
}

.addspot-cat-opt {
  position: relative;
  flex: 1 1 0;
  min-width: 0;
}

.addspot-cat-opt input {
  position: absolute;
  opacity: 0;
  width: 1px;
  height: 1px;
  pointer-events: none;
}

.addspot-cat-icon .om-cat-smoking-glyph,
.addspot-cat-icon .om-cat-toilet-glyph,
.addspot-cat-icon--trash-svg .om-cat-trash-glyph,
.post-cat-icon .om-cat-smoking-glyph,
.post-cat-icon .om-cat-toilet-glyph,
.post-cat-icon--trash-svg .om-cat-trash-glyph {
  width: 1.35rem;
  height: 1.35rem;
  display: block;
  fill: currentColor;
}

.addspot-cat-icon,
.om-category-ms {
  font-size: 1.875rem !important;
  font-variation-settings: 'FILL' 0;
  line-height: 1;
}

.addspot-cat-icon {
  color: var(--color-text-sub);
  transition: color var(--motion-base) var(--ease-standard);
}

.addspot-cat-text {
  display: block;
  max-width: 100%;
  overflow: hidden;
  text-overflow: ellipsis;
}

.addspot-cat-opt input:checked + .addspot-cat-chip {
  background: var(--color-primary);
  border-color: var(--color-primary);
  color: var(--color-on-primary);
  box-shadow: var(--shadow-filter-active);
}

.addspot-cat-opt input:checked + .addspot-cat-chip .addspot-cat-icon {
  color: var(--color-on-primary);
}

.addspot-cat-opt input:focus-visible + .addspot-cat-chip {
  outline: var(--focus-outline-accent);
  outline-offset: var(--focus-offset);
}

/* トイレ属性（複数選択） */
.addspot-attrs-group {
  margin-top: 2px;
}

/* スポット追加モーダル: ゴミ分別が日本語で2段折り返しになる高さに、喫煙・トイレのチップ行を揃える */
#add-spot-modal .addspot-smoking-type-row,
#add-spot-modal .addspot-attrs-row {
  min-height: calc(38px + 8px + 38px);
  align-content: flex-start;
}

.addspot-attrs-row {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.addspot-attr-opt {
  position: relative;
  flex: 0 1 auto;
}

.addspot-attr-opt input {
  position: absolute;
  opacity: 0;
  pointer-events: none;
  width: 1px;
  height: 1px;
}

.addspot-attr-chip {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  min-height: 38px;
  padding: 6px 12px;
  border: 1.5px solid var(--color-border);
  border-radius: 9999px;
  background: var(--color-surface-elevated);
  color: var(--color-text-sub);
  font-size: 12px;
  font-weight: 600;
  cursor: pointer;
  transition: background-color var(--motion-base) var(--ease-standard), border-color var(--motion-base) var(--ease-standard), color var(--motion-base) var(--ease-standard), box-shadow var(--motion-base) var(--ease-standard);
}

.addspot-attr-icon {
  font-size: 18px !important;
  font-variation-settings: 'FILL' 0;
  color: var(--color-text-sub);
  transition: color var(--motion-base) var(--ease-standard);
}

.addspot-attr-opt input:checked + .addspot-attr-chip {
  background: var(--color-primary);
  border-color: var(--color-primary);
  color: var(--color-on-primary);
  box-shadow: var(--shadow-filter-active-sm);
}

.addspot-attr-opt input:checked + .addspot-attr-chip .addspot-attr-icon {
  color: var(--color-on-primary);
}

.addspot-attr-opt input:focus-visible + .addspot-attr-chip {
  outline: var(--focus-outline-accent);
  outline-offset: var(--focus-offset);
}

/* ===== 喫煙所タバコ種別 選択 UI ===== */
.addspot-smoking-type-group {
  margin-top: 2px;
}

.addspot-smoking-type-row {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.addspot-smoking-type-opt {
  position: relative;
  flex: 0 1 auto;
}

.addspot-smoking-type-opt input {
  position: absolute;
  opacity: 0;
  pointer-events: none;
  width: 1px;
  height: 1px;
}

.addspot-smoking-type-chip {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  min-height: 38px;
  padding: 6px 14px;
  border: 1.5px solid var(--color-border);
  border-radius: 9999px;
  background: var(--color-surface-elevated);
  color: var(--color-text-sub);
  font-size: 13px;
  font-weight: 600;
  cursor: pointer;
  transition: background-color var(--motion-base) var(--ease-standard), border-color var(--motion-base) var(--ease-standard), color var(--motion-base) var(--ease-standard);
}

.smoking-type-icon {
  font-size: 18px !important;
  font-variation-settings: 'FILL' 0;
}

.addspot-smoking-type-opt input:checked + .addspot-smoking-type-chip {
  background: var(--color-primary);
  border-color: var(--color-primary);
  color: var(--color-on-primary);
}

.addspot-smoking-type-opt input:checked + .addspot-smoking-type-chip .smoking-type-icon {
  color: var(--color-on-primary);
}

.addspot-smoking-type-opt input:focus-visible + .addspot-smoking-type-chip {
  outline: var(--focus-outline-accent);
  outline-offset: var(--focus-offset);
}

.addspot-trash-types-group {
  margin-top: 2px;
}

.addspot-trash-row {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.addspot-trash-opt {
  position: relative;
  flex: 0 1 auto;
  cursor: pointer;
}

.addspot-trash-opt input {
  position: absolute;
  opacity: 0;
  pointer-events: none;
  width: 1px;
  height: 1px;
}

/* 喫煙タイプ・トイレ属性と同系のピルチップ（ゴミ分別メタのみ別デザインだった問題の統一） */
.addspot-trash-chip {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  min-height: 38px;
  padding: 6px 14px;
  border: 1.5px solid var(--color-border);
  border-radius: 9999px;
  background: var(--color-surface-elevated);
  color: var(--color-text-sub);
  font-size: 13px;
  font-weight: 600;
  cursor: pointer;
  transition: background-color var(--motion-base) var(--ease-standard), border-color var(--motion-base) var(--ease-standard), color var(--motion-base) var(--ease-standard);
}

.addspot-trash-opt input:checked + .addspot-trash-chip {
  background: var(--color-primary);
  border-color: var(--color-primary);
  color: var(--color-on-primary);
}

.addspot-trash-opt input:focus-visible + .addspot-trash-chip {
  outline: var(--focus-outline-accent);
  outline-offset: var(--focus-offset);
}

.addspot-trash-icon {
  font-size: 18px !important;
  font-variation-settings: 'FILL' 0;
}

.addspot-trash-opt input:checked + .addspot-trash-chip .addspot-trash-icon {
  color: var(--color-on-primary);
}

/* primary を addspot-modal でも使えるよう、スポット追加用の primary ボタンは
   ティール系（投稿のアンバーと差別化）。 */
.modal-btn-primary.is-addspot {
  background: var(--color-primary);
}
.modal-btn-primary.is-addspot:hover {
  background: var(--color-primary-dark);
}

/* ----- Hidden-by-reports state ----------------------------------------- */
.comment.is-hidden-by-reports {
  opacity: 0.55;
}

.comment.is-hidden-by-reports .comment-text {
  font-style: italic;
  color: var(--color-text-sub);
}

/* ----- Toast ------------------------------------------------------------- */
/* マイページ／認証モーダル等 .modal（z-index:200）より前面に出し、連携結果トーストが隠れないようにする */
.toast {
  position: absolute;
  left: 50%;
  bottom: calc(180px + var(--safe-bottom));
  transform: translateX(-50%);
  padding: 10px 16px;
  background: var(--color-overlay-toast);
  color: var(--color-on-primary);
  border-radius: var(--radius-pill);
  font-size: 14px;
  z-index: 300;
  box-shadow: var(--shadow-2);
  max-width: 88%;
  text-align: center;
}

/* SCR-11: ヒント（.add-spot-pin-hint の下端 188px）より上にトーストを出し、エリア外通知と重ならない */
body.add-spot-pin-mode #toast.toast {
  bottom: calc(188px + 5.5rem + 12px + var(--safe-bottom));
}

.toast.toast--single-line {
  white-space: nowrap;
  max-width: min(92vw, 100vw - 24px);
  overflow: hidden;
  text-overflow: ellipsis;
}

/* ----- Marker (custom HTML for AdvancedMarker) -------------------------- */
/* Marketing 提案 §6.2-6.3:
   - 形状をカテゴリ別に変更:
     smoking = circle (violet)
     trash   = rounded square (blue)
     toilet  = teardrop (teal-green)
   - 白フチ 2px + 二層シャドウ + 内側に白 SVG ピクトグラム */
.marker {
  position: relative;
  width: var(--pin-size);
  height: var(--pin-size);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: var(--color-primary);
  color: var(--color-on-primary);
  border: var(--pin-border) solid var(--color-on-primary);
  box-shadow: var(--pin-shadow);
  cursor: pointer;
  /* タッチ領域を 44x44 に拡張（透明な疑似要素） */
  transition: transform var(--motion-fast) var(--ease-standard), box-shadow var(--motion-fast) var(--ease-standard), background-color var(--motion-fast) var(--ease-standard);
}

.marker::before {
  /* タッチターゲット 44x44 確保（UX-MF-1） */
  content: "";
  position: absolute;
  inset: -4px;
  pointer-events: auto;
}

.marker__icon {
  width: 22px;
  height: 22px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  pointer-events: none;
}

.marker__icon svg {
  width: 100%;
  height: 100%;
  display: block;
  fill: var(--color-on-primary);
}

/* 喫煙のみ Material Symbol。ゴミ箱はスポット詳細と同一 SVG（delete グリフは使わない） */
.marker__icon .marker__ms {
  font-size: 22px;
  line-height: 1;
  color: var(--color-on-primary);
  font-variation-settings: "FILL" 1, "wght" 500, "GRAD" 0, "opsz" 24;
  user-select: none;
}

.marker.is-selected .marker__icon .marker__ms {
  font-size: 26px;
}

/* カテゴリ別形状（外形シルエット） */
.marker[data-category="smoking"] {
  background: var(--color-cat-smoking);
  border-radius: 50%;
}
.marker[data-category="trash"] {
  background: var(--color-cat-trash);
  border-radius: 10px;
}
.marker[data-category="toilet"] {
  background: var(--color-cat-toilet);
  /* 水滴形: 上3角・左下のみ尖らせ、回転で下尖りにする */
  border-radius: 50% 50% 50% 0;
  transform: rotate(-45deg);
}
/* 内側 SVG は形状回転を打ち消して向きを揃える */
.marker[data-category="toilet"] .marker__icon {
  transform: rotate(45deg);
}

/* ホバー（PC） */
@media (hover: hover) {
  .marker:hover {
    box-shadow: var(--pin-shadow-hover);
  }
}

/* 選択状態（タップ後） */
.marker.is-selected {
  width: var(--pin-size-selected);
  height: var(--pin-size-selected);
  border-width: 3px;
  box-shadow: var(--pin-shadow-selected);
  z-index: 2;
}

.marker.is-selected .marker__icon {
  width: 26px;
  height: 26px;
}

.marker[data-category="smoking"].is-selected {
  animation: om-pin-pulse-smoking 1.6s ease-out infinite;
}
.marker[data-category="trash"].is-selected {
  animation: om-pin-pulse-trash 1.6s ease-out infinite;
}
.marker[data-category="toilet"].is-selected {
  animation: om-pin-pulse-toilet 1.6s ease-out infinite;
}

@keyframes om-pin-pulse-smoking {
  0%   { box-shadow: var(--pin-shadow-selected), 0 0 0 0 var(--color-cat-smoking-pulse); }
  100% { box-shadow: var(--pin-shadow-selected), 0 0 0 14px rgba(59, 130, 246, 0); }
}
@keyframes om-pin-pulse-trash {
  0%   { box-shadow: var(--pin-shadow-selected), 0 0 0 0 var(--color-cat-trash-pulse); }
  100% { box-shadow: var(--pin-shadow-selected), 0 0 0 14px rgba(6, 182, 212, 0); }
}
@keyframes om-pin-pulse-toilet {
  0%   { box-shadow: var(--pin-shadow-selected), 0 0 0 0 var(--color-cat-toilet-pulse); }
  100% { box-shadow: var(--pin-shadow-selected), 0 0 0 14px rgba(139, 92, 246, 0); }
}

/* クラスタピン（Marketing 提案 §6.4） */
.cluster {
  width: 48px;
  height: 48px;
  border-radius: 50%;
  border: 2px solid var(--color-on-primary);
  background: var(--color-text-sub);
  color: var(--color-on-primary);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-weight: 700;
  font-size: 14px;
  box-shadow: var(--shadow-2);
}

.cluster[data-category="smoking"] { background: var(--color-cat-smoking); }
.cluster[data-category="trash"]   { background: var(--color-cat-trash); }
.cluster[data-category="toilet"]  { background: var(--color-cat-toilet); }
.cluster--mixed { background: var(--color-cluster-mixed); }

/* ----- My Page (F-13) — Local Hero トーン ------------------------------- */

.mypage-modal {
  align-items: flex-start;
  justify-content: flex-end;
}

.mypage-modal .mypage-panel {
  height: 100%;
  max-height: 100%;
  max-width: 400px;
  width: 92vw;
  border-radius: var(--radius-md) 0 0 var(--radius-md);
  border-top-right-radius: 0;
  border-bottom-right-radius: 0;
  padding: 0;
  transform: translateX(100%);
  display: flex;
  flex-direction: column;
  overflow: hidden;
  background: var(--color-bg);
  box-shadow: var(--shadow-drawer);
}

.mypage-modal[aria-hidden="false"] .mypage-panel {
  transform: translateX(0);
}

/* ヒーロー: 明るいプロフィール + アンバーチップ */
.mp-hero--local {
  flex: 0 0 auto;
  position: relative;
  text-align: center;
  background: linear-gradient(180deg, var(--color-surface-elevated) 0%, var(--color-surface-hero-end) 100%);
  padding: calc(14px + var(--safe-top) + var(--header-height)) 20px 20px;
  border-bottom: 1px solid var(--color-border-brand-subtle);
}

.mp-back {
  position: absolute;
  top: calc(10px + var(--safe-top) + var(--header-height));
  left: 10px;
  width: var(--tap);
  height: var(--tap);
  border-radius: 50%;
  border: none;
  background: rgba(250, 250, 250, 0.92);
  color: var(--color-primary);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  box-shadow: var(--shadow-1);
  cursor: pointer;
  transition: background-color var(--motion-base) var(--ease-standard), transform var(--motion-fast) var(--ease-standard);
}

.mp-back:active {
  transform: scale(0.96);
  background: var(--color-surface-elevated);
}

.mp-back-icon {
  font-size: 22px !important;
}

.mp-local-hero-badge {
  margin: 0 0 12px;
  padding: 4px 12px;
  display: inline-block;
  font-family: var(--font-display);
  font-size: 11px;
  font-weight: var(--font-weight-label);
  letter-spacing: var(--letter-spacing-label);
  text-transform: var(--text-transform-label);
  color: var(--color-primary);
  background: var(--color-action-soft);
  border-radius: var(--radius-chip);
}
.mp-local-hero-badge[hidden] { display: none; }

.mp-profile-block {
  display: flex;
  align-items: center;
  gap: 14px;
  margin-bottom: 16px;
  padding-left: 44px;
}

.mp-avatar {
  width: 64px;
  height: 64px;
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  background: linear-gradient(145deg, var(--color-avatar-gradient-start) 0%, var(--color-avatar-gradient-end) 100%);
  overflow: hidden;
  box-shadow: var(--shadow-2);
}

.mp-avatar-fallback {
  font-size: 38px !important;
  color: var(--color-primary);
  opacity: 0.85;
}

.mp-avatar-twitter-ring {
  width: 100%;
  height: 100%;
  border-radius: 50%;
  background: #000;
  display: flex;
  align-items: center;
  justify-content: center;
}

.mp-avatar-twitter-svg {
  width: 52%;
  height: 52%;
  color: var(--color-on-primary);
}

.mp-avatar-photo {
  width: 100%;
  height: 100%;
  border-radius: 50%;
  object-fit: cover;
}

.mp-profile-copy {
  min-width: 0;
  flex: 1;
  text-align: left;
}

.mp-display-name {
  margin: 0 0 4px;
  font-family: var(--font-display);
  font-size: 1.25rem;
  font-weight: var(--font-weight-display);
  letter-spacing: var(--letter-spacing-display);
  color: var(--color-primary);
  line-height: 1.25;
}

.mp-account-sub {
  margin: 0;
  font-size: 0.8125rem;
  color: var(--color-text-sub);
  line-height: 1.4;
  word-break: break-word;
}

.mp-stat-chips {
  display: flex;
  gap: 10px;
  padding-left: 44px;
}

.mp-stat-chip {
  flex: 1;
  min-width: 0;
  padding: 12px 10px 14px;
  border-radius: var(--radius-card);
  background: var(--color-action-soft);
  text-align: center;
  box-shadow: var(--shadow-card);
}

.mp-stat-chip-val {
  display: block;
  font-family: var(--font-display);
  font-size: 1.75rem;
  font-weight: var(--font-weight-semibold);
  line-height: 1.1;
  color: var(--color-action);
  letter-spacing: var(--letter-spacing-tight);
}

.mp-stat-chip-lbl {
  display: block;
  margin-top: 4px;
  font-size: 0.6875rem;
  font-weight: var(--font-weight-label);
  letter-spacing: var(--letter-spacing-label);
  text-transform: var(--text-transform-label);
  color: var(--color-text-sub);
}

.mp-stat-chip:has(#mypage-thanks-total) {
  background: var(--color-warm-soft);
}

.mp-stat-chip:has(#mypage-thanks-total) .mp-stat-chip-val,
.mp-stat-chip:has(#mypage-thanks-total) .mp-stat-chip-lbl {
  color: var(--color-warm-dark);
}

/* マイページスクロール末尾（利用規約の上）。ヒーロー内には置かない */
.mypage-section.mp-feedback {
  border-top: 1px solid rgba(0, 0, 0, 0.06);
}

.mp-feedback {
  margin: 0;
  padding: 0;
  border-top: none;
  text-align: left;
}

.mp-feedback-title {
  margin: 0 0 6px;
  font-family: var(--font-display);
  font-size: 0.875rem;
  font-weight: 700;
  color: var(--color-primary);
  letter-spacing: -0.01em;
}

.mp-feedback-hint {
  margin: 0 0 10px;
  font-size: 0.75rem;
  line-height: 1.5;
  color: var(--color-text-sub);
}

.mp-feedback-label {
  display: block;
  margin: 0 0 6px;
  font-size: 0.8125rem;
  font-weight: 700;
  letter-spacing: -0.01em;
  text-transform: none;
  color: var(--color-primary);
}

.mp-feedback-text {
  display: block;
  width: 100%;
  box-sizing: border-box;
  min-height: 88px;
  padding: 10px 12px;
  margin: 0 0 8px;
  font: inherit;
  font-size: 0.875rem;
  line-height: 1.45;
  color: var(--color-text);
  background: var(--input-bg);
  border: 1px solid var(--input-border);
  border-radius: var(--input-radius);
  box-shadow: var(--input-shadow);
  resize: vertical;
  transition: border-color var(--motion-base) var(--ease-standard), box-shadow var(--motion-base) var(--ease-standard);
}

.mp-feedback-text:focus {
  outline: none;
  border-color: var(--input-border-focus);
  box-shadow: var(--input-shadow-focus);
}

.mp-feedback-toolbar {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 10px;
  flex-wrap: wrap;
}

.mp-feedback-toolbar .mp-feedback-counter {
  margin-right: auto;
}

.mp-feedback-counter {
  font-size: 0.75rem;
  color: var(--color-text-sub);
  font-variant-numeric: tabular-nums;
}

.mp-feedback-submit {
  flex-shrink: 0;
  padding: 8px 18px;
  min-height: 40px;
}

.mypage-scroll {
  flex: 1 1 auto;
  min-height: 0;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
}

.mypage-section {
  padding: 16px 20px 18px;
  border-bottom: 1px solid rgba(0, 0, 0, 0.06);
  background: var(--color-bg);
}

.mypage-section--posts {
  border-bottom: none;
  padding-bottom: 8px;
}

.mypage-section-title {
  margin: 0 0 10px;
  font-size: 0.75rem;
  font-weight: var(--font-weight-label);
  letter-spacing: var(--letter-spacing-label);
  text-transform: var(--text-transform-label);
  color: var(--color-text-sub);
}

.mypage-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.mypage-btn {
  min-height: var(--tap);
  padding: 0 14px;
  border-radius: var(--radius-button);
  font-size: 14px;
  font-weight: var(--font-weight-button);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 1px solid transparent;
  transition: background-color var(--motion-base) var(--ease-standard), transform var(--motion-fast) var(--ease-standard);
}

.mypage-btn:active { transform: scale(0.98); }

.mypage-btn-google {
  background: var(--color-surface-elevated);
  color: var(--color-text);
  border-color: var(--color-border);
}
.mypage-btn-google:hover { background: var(--color-surface); }

.mypage-btn-twitter {
  background: #000000;
  color: var(--color-on-primary);
}
.mypage-btn-twitter:hover { background: #1a1a1a; }

.mypage-btn-secondary {
  background: var(--color-surface);
  color: var(--color-text);
  border-color: var(--color-border);
}
.mypage-btn-secondary:hover { background: var(--color-surface-2); }

.mypage-btn-primary {
  background: var(--color-action);
  color: var(--color-on-primary);
}
.mypage-btn-primary:hover { background: var(--color-action-hover); }
.mypage-btn-primary:disabled { opacity: 0.55; cursor: not-allowed; }

.mypage-nickname-row {
  display: flex;
  gap: 8px;
  align-items: center;
}

.mypage-nickname-input {
  flex: 1;
  min-height: var(--tap);
  padding: 0 12px;
  border: 1px solid var(--input-border);
  border-radius: var(--input-radius);
  font-size: 14px;
  font-family: inherit;
  color: var(--color-text);
  background: var(--input-bg);
  box-shadow: var(--input-shadow);
  outline: none;
  transition: border-color var(--motion-base) var(--ease-standard), box-shadow var(--motion-base) var(--ease-standard);
}
.mypage-nickname-input:focus {
  border-color: var(--input-border-focus);
  box-shadow: var(--input-shadow-focus);
}

.mypage-posts {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.mypage-empty {
  margin: 20px 0;
  text-align: center;
  font-size: 14px;
  color: var(--color-text-sub);
  line-height: 1.5;
}

/* 投稿カード */
.mypage-post-card {
  padding: 14px 14px 12px;
  border-radius: 20px;
  background: var(--color-surface-elevated);
  border: none;
  box-shadow: var(--shadow-card-composite);
}

.mypage-post-top {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  margin-bottom: 10px;
}

.mypage-post-icon-wrap {
  flex-shrink: 0;
  width: 48px;
  height: 48px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--color-surface);
}

/* マイページのカテゴリアイコン — 地図ピン（.marker）と同一の実色・白グリフ・外形 */
.mypage-post-icon-wrap--smoking,
.mypage-post-icon-wrap--trash,
.mypage-post-icon-wrap--toilet {
  border: var(--pin-border) solid var(--color-on-primary);
  box-shadow: var(--pin-shadow);
  color: var(--color-on-primary);
}

.mypage-post-icon-wrap--smoking {
  background: var(--color-cat-smoking);
  border-radius: 50%;
}
.mypage-post-icon-wrap--trash {
  background: var(--color-cat-trash);
  border-radius: 10px;
}
.mypage-post-icon-wrap--toilet {
  background: var(--color-cat-toilet);
  border-radius: 50% 50% 50% 0;
  transform: rotate(-45deg);
}
.mypage-post-icon-wrap--toilet > * {
  transform: rotate(45deg);
}

.mypage-post-icon-wrap--smoking .om-cat-smoking-glyph,
.mypage-spot-icon-wrap--smoking .om-cat-smoking-glyph {
  width: 1.75rem;
  height: 1.75rem;
  display: block;
  fill: currentColor;
}

.mypage-post-icon-wrap .om-cat-trash-glyph,
.mypage-spot-icon-wrap .om-cat-trash-glyph,
.mypage-post-icon-wrap .om-cat-toilet-glyph,
.mypage-spot-icon-wrap .om-cat-toilet-glyph,
.mypage-post-icon-wrap .om-cat-smoking-glyph,
.mypage-spot-icon-wrap .om-cat-smoking-glyph,
/* trashCategoryIconSvg はクラス無しで注入される経路があるため親でも指定 */
.mypage-post-icon-wrap--trash > svg,
.mypage-spot-icon-wrap--trash > svg {
  width: 1.75rem;
  height: 1.75rem;
  display: block;
  fill: currentColor;
}

.mypage-post-icon-wrap--unknown {
  background: #eceff1;
  color: #607d8b;
}

.mypage-post-meta {
  flex: 1;
  min-width: 0;
  padding-top: 2px;
}

.mypage-post-place {
  margin: 0 0 4px;
  font-size: 1rem;
  font-weight: 700;
  line-height: 1.25;
  color: var(--color-text);
  word-break: break-word;
}

.mypage-post-place .mypage-post-hidden-badge {
  display: inline-block;
  margin-left: 8px;
  padding: 2px 8px;
  font-size: 0.7rem;
  font-weight: 600;
  vertical-align: middle;
  border-radius: 999px;
  background: rgba(97, 97, 97, 0.12);
  color: var(--color-text-sub);
  letter-spacing: 0.02em;
}

.mypage-post-card--hidden .mypage-post-bubble {
  opacity: 0.92;
}

.mypage-post-card--spot-nav {
  cursor: pointer;
}

.mypage-post-card--spot-nav:hover {
  box-shadow: var(--shadow-elevated-composite);
}

.mypage-post-card--spot-nav:focus-visible {
  outline: var(--focus-outline-accent);
  outline-offset: var(--focus-offset);
}

.mypage-post-card .mypage-post-date {
  font-size: 0.75rem;
  font-weight: 500;
  color: var(--color-text-sub);
}

.mypage-post-bubble {
  margin: 0 0 10px;
  padding: 10px 12px;
  border-radius: 14px 16px 16px 16px;
  background: #f0f2f5;
  border: 1px solid rgba(0, 0, 0, 0.05);
}

.mypage-post-card .mypage-post-text {
  margin: 0;
  font-size: 0.875rem;
  line-height: 1.55;
  color: var(--color-text);
  white-space: pre-wrap;
  word-break: break-word;
}

.mypage-post-foot {
  display: flex;
  align-items: center;
  gap: 8px;
}

.mypage-post-foot-grow {
  flex: 1 1 auto;
  min-width: 0;
}

.mypage-post-delete {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 40px;
  min-height: 40px;
  margin: 0;
  padding: 0;
  border: none;
  border-radius: 10px;
  background: transparent;
  color: var(--color-muted, #666);
  cursor: pointer;
  flex-shrink: 0;
}

.mypage-post-delete:hover {
  background: rgba(0, 0, 0, 0.06);
  color: var(--color-danger, #c0392b);
}

.mypage-post-delete:focus-visible {
  outline: var(--focus-outline-accent);
  outline-offset: var(--focus-offset);
}

.mypage-post-delete:disabled {
  opacity: 0.45;
  cursor: default;
}

.mypage-post-delete-icon {
  font-size: 22px !important;
}

.mypage-post-thanks {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-size: 0.8125rem;
  font-weight: var(--font-weight-semibold);
  color: var(--color-text-sub);
}

.mypage-post-thanks .om-thanks-ms {
  font-size: 20px !important;
}

.mypage-post-thanks-num {
  font-variant-numeric: tabular-nums;
}

.mypage-signout-row {
  padding: 8px 20px 6px;
  display: flex;
  justify-content: center;
  background: var(--color-bg);
}

.mypage-btn-signout {
  width: 100%;
  max-width: 280px;
  min-height: 44px;
  padding: 0 20px;
  border-radius: 999px;
  font: inherit;
  font-size: 0.875rem;
  font-weight: 600;
  color: var(--color-danger);
  background: transparent;
  border: 1.5px solid var(--color-danger);
  cursor: pointer;
  transition: background-color var(--motion-base) var(--ease-standard), color var(--motion-base) var(--ease-standard);
}

.mypage-btn-signout:hover {
  background: rgba(192, 57, 43, 0.06);
}

.mypage-btn-signout:focus-visible {
  outline: var(--focus-outline-accent);
  outline-offset: var(--focus-offset);
}

.mypage-legal {
  padding: 12px 20px calc(16px + var(--safe-bottom));
  display: flex;
  flex-wrap: wrap;
  gap: 12px 16px;
  justify-content: center;
  font-size: 12px;
  background: var(--color-bg);
}

.mypage-legal a {
  color: var(--color-text-sub);
  text-decoration: none;
  border-bottom: 1px solid transparent;
}

.mypage-legal a:hover {
  color: var(--color-text);
  border-bottom-color: var(--color-border);
}

/* F-15 / F-16 — スポットシートツールバー・タイムライン・追加スポット一覧 */
.sheet-spot-toolbar {
  margin-top: 8px;
  padding: 8px 0 4px;
  border-top: 1px solid rgba(0, 0, 0, 0.06);
  align-self: stretch;
  width: 100%;
  box-sizing: border-box;
}

.sheet-spot-toolbar-row {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 8px;
}

.sheet-spot-toolbar-spacer {
  flex: 1;
  min-width: 0;
}

.sheet-toolbar-btn {
  min-width: 44px;
  min-height: 44px;
  border-radius: 12px;
  border: 1px solid rgba(0, 0, 0, 0.12);
  background: var(--color-surface-elevated);
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0 8px;
  color: var(--color-text-sub);
}

.sheet-toolbar-ic {
  font-size: 22px !important;
  font-variation-settings: 'FILL' 0, 'wght' 500, 'GRAD' 0, 'opsz' 24;
  line-height: 1;
}

#sheet-spot-thanks-btn {
  gap: 5px;
  min-width: 3.25rem;
}

.sheet-toolbar-btn .sheet-spot-thanks-count {
  font-weight: 600;
  font-size: 0.9rem;
  font-variant-numeric: tabular-nums;
  line-height: 1;
  color: inherit;
}

#sheet-spot-thanks-btn.is-thanked {
  background: var(--color-warm-soft);
  border-color: transparent;
  color: var(--color-warm-dark);
}
#sheet-spot-thanks-btn.is-thanked .om-thanks-ms {
  color: var(--color-warm-dark);
  font-variation-settings: 'FILL' 1;
}
#sheet-spot-thanks-btn.is-thanked .sheet-spot-thanks-count {
  color: var(--color-warm-dark);
}

.sheet-toolbar-btn:hover {
  background: var(--color-surface-2, #f3f4f6);
}

.sheet-toolbar-btn:active {
  transform: scale(0.96);
}

.sheet-toolbar-btn:focus-visible {
  outline: var(--focus-outline-accent);
  outline-offset: var(--focus-offset);
}

.sheet-toolbar-btn--danger {
  border-color: var(--color-danger);
  color: var(--color-danger);
}

.sheet-toolbar-btn--danger .sheet-toolbar-ic {
  color: var(--color-danger);
}

.comment--meta .comment-text--meta {
  font-size: 0.92rem;
  color: var(--color-text-sub);
}

.badge--meta {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  background: var(--color-info-soft);
  color: var(--color-info);
  font-size: 0.7rem;
  padding: 2px 8px;
  border-radius: 8px;
}

.badge-meta-ic {
  font-size: 15px !important;
  font-variation-settings: 'FILL' 0;
  line-height: 1;
}

.spot-meta-fieldset {
  margin: 12px 0;
  border: 0;
  padding: 0;
}

.spot-meta-check {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  margin: 12px 0;
  font-size: 13px;
  line-height: 1.45;
}

.mypage-spot-card {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 12px;
  margin-bottom: 10px;
  border-radius: var(--radius-card);
  background: var(--color-surface-elevated);
  border: none;
  box-shadow: var(--shadow-card);
  cursor: pointer;
}

.mypage-spot-card:focus-visible {
  outline: var(--focus-outline-accent);
  outline-offset: var(--focus-offset);
}

.mypage-spot-body {
  flex: 1;
  min-width: 0;
}

.mypage-spot-title-row {
  display: flex;
  align-items: flex-start;
  gap: 10px;
}

.mypage-spot-title-row .mypage-spot-title {
  flex: 1;
  min-width: 0;
}

.mypage-spot-thanks-inline {
  flex-shrink: 0;
  margin: 0;
}

.mypage-spot-icon-wrap {
  width: 44px;
  height: 44px;
  border-radius: 12px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: #f3f4f6;
  flex-shrink: 0;
}

.mypage-spot-icon-wrap--smoking,
.mypage-spot-icon-wrap--trash,
.mypage-spot-icon-wrap--toilet {
  border: var(--pin-border) solid var(--color-on-primary);
  box-shadow: var(--pin-shadow);
  color: var(--color-on-primary);
}

.mypage-spot-icon-wrap--smoking {
  background: var(--color-cat-smoking);
  border-radius: 50%;
}

.mypage-spot-icon-wrap--trash {
  background: var(--color-cat-trash);
  border-radius: 10px;
}

.mypage-spot-icon-wrap--toilet {
  background: var(--color-cat-toilet);
  border-radius: 50% 50% 50% 0;
  transform: rotate(-45deg);
}

.mypage-spot-icon-wrap--toilet > * {
  transform: rotate(45deg);
}

.mypage-spot-icon-wrap--smoking .om-cat-smoking-glyph {
  width: 1.5rem;
  height: 1.5rem;
  display: block;
  fill: currentColor;
}

.mypage-spot-title {
  margin: 0;
  font-size: 15px;
  font-weight: 600;
}

.mypage-spot-hidden-badge {
  display: inline-block;
  margin-left: 8px;
  font-size: 11px;
  font-weight: 600;
  padding: 2px 8px;
  border-radius: 8px;
  background: var(--color-danger-soft);
  color: var(--color-danger);
}

/* =========================================================================
   Auth Modal — sign-in gate before posting
   Google ブランドガイドライン: https://developers.google.com/identity/branding-guidelines
   X ブランドガイドライン: https://about.x.com/en/who-we-are/brand-toolkit
   ========================================================================= */
.auth-panel {
  text-align: center;
  padding-top: 20px;
}

.auth-subtitle {
  margin: 4px 0 28px;
  font-size: 14px;
  color: var(--color-text-sub);
  line-height: 1.55;
}

.auth-actions {
  display: flex;
  flex-direction: column;
  gap: 12px;
  margin-bottom: 8px;
}

/* --- 共通ボタン基盤 --- */
.auth-btn {
  width: 100%;
  min-height: 48px;
  border-radius: var(--radius-md);
  font-size: 15px;
  font-weight: 600;
  letter-spacing: 0.01em;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 12px;
  border: none;
  cursor: pointer;
  transition: background-color var(--motion-base) var(--ease-standard), box-shadow var(--motion-base) var(--ease-standard), opacity var(--motion-fast) var(--ease-standard);
  padding: 0 20px;
}
.auth-btn:disabled {
  opacity: 0.55;
  cursor: not-allowed;
}
.auth-btn:active:not(:disabled) {
  opacity: 0.84;
  transform: scale(0.99);
}

.auth-btn-logo {
  flex-shrink: 0;
  display: block;
}

/* --- Google 公式ボタン（白背景 / カラーロゴ） --- */
.auth-btn-google {
  background: var(--color-surface-elevated);
  color: #3c4043;
  border: 1px solid #dadce0;
  box-shadow: 0 1px 2px rgba(60, 64, 67, 0.12), 0 1px 3px rgba(60, 64, 67, 0.08);
  font-family: Roboto, -apple-system, BlinkMacSystemFont, sans-serif;
}
.auth-btn-google:hover:not(:disabled) {
  background: #f8f9fa;
  box-shadow: 0 1px 3px rgba(60, 64, 67, 0.2), 0 2px 6px rgba(60, 64, 67, 0.10);
}
.auth-btn-google:focus-visible {
  outline: 3px solid #4285f4;
  outline-offset: 2px;
}

/* --- X 公式ボタン（黒背景 / 白ロゴ） --- */
.auth-btn-x {
  background: #000000;
  color: var(--color-on-primary);
}
.auth-btn-x:hover:not(:disabled) { background: #0d0d0d; }
.auth-btn-x:focus-visible {
  outline: 3px solid #555;
  outline-offset: 2px;
}

/* --- ゲストスキップリンク --- */
.auth-skip {
  margin-top: 4px;
  padding: 10px 16px;
  font-size: 13px;
  color: var(--color-text-sub);
  text-decoration: underline;
  text-underline-offset: 2px;
  cursor: pointer;
  background: none;
  border: none;
  transition: color var(--motion-fast) var(--ease-standard);
}
.auth-skip:hover { color: var(--color-text); }

/* --- mypage 内の連携ボタン: アイコン付き全幅スタイルに統一 --- */
.mypage-btn-logo {
  flex-shrink: 0;
  display: block;
}

.mypage-btn-google,
.mypage-btn-twitter {
  width: 100%;
  gap: 10px;
  font-family: Roboto, -apple-system, BlinkMacSystemFont, sans-serif;
}

/* ----- Current Location Dot (AdvancedMarkerElement) ---------------------- */
.loc-dot-wrap {
  position: relative;
  width: 20px;
  height: 20px;
  transform: translateX(-50%) translateY(-50%);
}

.loc-ring {
  position: absolute;
  inset: 0;
  border-radius: 50%;
  background: var(--color-primary);
  animation: locPulse 2.4s ease-out infinite;
}

.loc-center {
  position: absolute;
  top: 3px;
  left: 3px;
  width: 14px;
  height: 14px;
  border-radius: 50%;
  background: var(--color-primary);
  border: 3px solid white;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.25);
}

@keyframes locPulse {
  0%   { transform: scale(1); opacity: 0.45; }
  100% { transform: scale(4); opacity: 0; }
}

/* ----- Reduced motion ---------------------------------------------------- */
@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    animation-duration: 0.001ms !important;
    transition-duration: 0.001ms !important;
  }
}

/* ----- Larger phones / landscape ---------------------------------------- */
@media (min-width: 768px) {
  .sheet {
    max-width: 480px;
    left: 50%;
    transform: translate(-50%, 100%);
    border-radius: var(--radius-lg);
    bottom: 24px;
  }
  .sheet.is-open {
    transform: translate(-50%, 0);
  }
}

/* ----- Business hours: sheet display ------------------------------------- */
.sheet-hours {
  padding: 8px 20px 4px;
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.sheet-hours-row {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 0.85rem;
  line-height: 1.4;
}

.sheet-hours-day {
  flex: 0 0 2.5em;
  font-weight: 600;
  color: var(--text-secondary, #555);
}

.sheet-hours-time {
  color: var(--text-primary, #222);
}

/* ----- Business hours: modal input --------------------------------------- */
.addspot-hours-group {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  min-width: 0;
  gap: 0;
}

.addspot-hours-group > legend {
  float: none;
  position: static;
  display: block;
  width: 100%;
  max-width: 100%;
  box-sizing: border-box;
  margin: 0 0 8px;
  padding: 0;
}

.addspot-hours-grid {
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.addspot-hours-row {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 4px 0;
  font-size: 0.875rem;
}

.addspot-hours-day {
  flex: 0 0 2em;
  font-weight: 600;
  color: var(--text-secondary, #555);
  text-align: center;
}

.addspot-hours-open,
.addspot-hours-close {
  flex: 1 1 0;
  min-width: 0;
  padding: 5px 6px;
  border: 1px solid var(--border-color, #ccc);
  border-radius: var(--radius-sm, 6px);
  font-size: 0.875rem;
  background: var(--color-surface-elevated);
  color: var(--text-primary, #222);
}

.addspot-hours-open:disabled,
.addspot-hours-close:disabled {
  opacity: 0.35;
  pointer-events: none;
}

.addspot-hours-sep {
  flex: 0 0 auto;
  color: var(--text-secondary, #777);
  user-select: none;
}

.addspot-hours-closed-wrap {
  display: flex;
  align-items: center;
  gap: 4px;
  flex: 0 0 auto;
  font-size: 0.8rem;
  color: var(--text-secondary, #555);
  cursor: pointer;
  white-space: nowrap;
}

.addspot-hours-closed-wrap input[type="checkbox"] {
  margin: 0;
  cursor: pointer;
}

/* Open-now filter chip */
.open-now-bar {
  display: flex;
  width: 100%;
  min-width: 0;
  flex-shrink: 0;
  box-sizing: border-box;
}

.open-now-chip {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  min-height: var(--tap);
  padding: 0 14px;
  border-radius: var(--radius-chip);
  border: none;
  background: var(--color-surface-elevated);
  color: var(--color-action);
  font-size: 12px;
  font-weight: var(--font-weight-label);
  line-height: 1;
  cursor: pointer;
  box-shadow: var(--shadow-card);
  transition: background var(--motion-base) var(--ease-standard), color var(--motion-base) var(--ease-standard), box-shadow var(--motion-base) var(--ease-standard);
  white-space: nowrap;
  -webkit-tap-highlight-color: transparent;
  box-sizing: border-box;
  max-width: 100%;
}

.open-now-chip.is-active {
  background: var(--color-action);
  color: var(--color-on-primary);
  border-color: transparent;
  box-shadow: var(--shadow-chip-active);
}

.open-now-icon {
  font-size: 14px;
}

/* ----- Report Modal (1-B-4) ---------------------------------------------- */
.report-reason-fieldset {
  border: 0;
  padding: 0;
  margin: 0 0 16px;
}

.report-reason-fieldset > legend.modal-label {
  float: none;
  position: static;
  display: block;
  margin-bottom: 8px;
}

.report-reason-opts {
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.report-reason-opt {
  display: flex;
  align-items: center;
  gap: 10px;
  min-height: var(--tap);
  padding: 0 4px;
  border-radius: 8px;
  cursor: pointer;
  font-size: 0.9375rem;
}

.report-reason-opt:hover {
  background: var(--color-bg-sub);
}

.report-reason-opt input[type="radio"] {
  width: 20px;
  height: 20px;
  accent-color: var(--color-primary);
  flex-shrink: 0;
  cursor: pointer;
}
