/* ========= ホーム（見出し） ========= */
.home-head{ padding:14px 0 18px; }
.home-lead{ margin:0; color:rgba(31,36,48,.70); font-size:13px; }

/* ========= グリッド ========= */
.grid{
  display:grid;
  grid-template-columns:repeat(12,1fr);
  gap:14px;
}
@media (max-width:560px){ .grid{ gap:12px; } }

/* ========= カード ========= */
/* カード本体（wrapperはリンクではない） */
.card{
  position:relative;
  grid-column:span 4;
  min-height:260px;
  border-radius:var(--radius2);
  overflow:hidden;
  border:1px solid var(--line);
  box-shadow:var(--shadow);
  background:var(--card);
}
@media (max-width:980px){ .card{ grid-column:span 6; min-height:240px; } }
@media (max-width:560px){ .card{ grid-column:span 12; min-height:220px; } }

/* クリック領域（全面リンク） */
.card-link{ position:absolute; inset:0; display:block; border-radius:inherit; }

/* 画像レイヤ */
.card-media{ position:absolute; inset:0; z-index:0; }
.card-media img{
  width:100%;
  height:100%;
  object-fit:cover;
  transform:scale(1.01);
  filter:saturate(1.02);
}

/* かぶせ（ホバー/開閉で濃くする） */
.card-overlay{
  position:absolute;
  inset:0;
  z-index:1;
  background:linear-gradient(
    to top,
    rgba(255,255,255,.88),
    rgba(255,255,255,.26) 55%,
    rgba(255,255,255,.10)
  );
  opacity:.22;
  transition:opacity .22s ease;
}

/* メタ（初期は非表示、PCホバー/スマホ開閉で表示） */
.card-meta{
  position:absolute;
  inset:auto 0 0 0;
  z-index:2;
  padding:14px 14px 12px;
  opacity:0;
  transform:translateY(10px);
  transition:opacity .18s ease, transform .18s ease;
  pointer-events:none; /* リンククリックを邪魔しない */
}
@media (max-width:560px){ .card-meta{ padding:12px 12px 10px; } }

/* メタの白パネル */
.card-panel{
  border-radius:18px;
  border:1px solid rgba(242,166,191,.22);
  background:rgba(255,255,255,.88);
  backdrop-filter:blur(10px);
  box-shadow:var(--shadow2);
  padding:12px 12px 10px;
  display:flex;
  flex-direction:column;
  gap:0; /* 余白は行で管理 */
}

/* 行（タイトル+日付 / カテゴリ+PHOTO+Like / タグ） */
.card-row{
  display:flex;
  align-items:baseline;
  justify-content:space-between;
  gap:10px;
}
.card-row--top{ margin-bottom:10px; } /* タイトルを目立たせる */
.card-row--mid{
  justify-content:flex-start; /* PHOTOは右寄せしない */
  gap:8px;
  margin:0;                  /* タグとの距離を最短に */
}
.card-title{
  font-size:14px;
  font-weight:950;
  line-height:1.25;
  letter-spacing:.15px;
  color:rgba(31,36,48,.94);
}
.card-row--top .card-title{ flex:1; min-width:0; }
.card-date{
  font-size:11px;
  font-weight:900;
  letter-spacing:.4px;
  color:rgba(31,36,48,.62);
  white-space:nowrap;
}

/* カード内のカテゴリ/PHOTOのチップ（サイズのみ統一、色は既存クラスを尊重） */
.pill-sm{
  font-size:11px;
  padding:0 .45rem;
  line-height:1.6;
  border-radius:999px;
  letter-spacing:.30px;
}

/* Like数（表示のみ） */
.card-like{
  margin-left:auto;
  display:inline-flex;
  align-items:center;
  gap:6px;
  font-size:11px;
  font-weight:900;
  letter-spacing:.3px;
  color:rgba(31,36,48,.62);
  user-select:none;
  pointer-events:none;
}
.card-like-count{
  font-variant-numeric:tabular-nums;
  min-width:1.2em;
  text-align:right;
}

/* タグ */
.card-tags{
  margin:0;
  display:flex;
  flex-wrap:wrap;
  gap:6px;
  color:rgba(31,36,48,.66);
  font-size:11px;
}
.card-tags .tag{ font-weight:700; opacity:.9; }

/* PC：ホバーで表示 / スマホ：is-openで表示 */
@media (hover:hover){
  .card:hover .card-overlay{ opacity:.72; }
  .card:hover .card-meta{ opacity:1; transform:translateY(0); }
  .card-info{ display:none !important; } /* PCではiを出さない */
}
.card.is-open .card-overlay{ opacity:.72; }
.card.is-open .card-meta{ opacity:1; transform:translateY(0); }

/* スマホ用 i ボタン（薄め） */
.card-info{
  position:absolute;
  right:12px;
  bottom:12px;
  z-index:3;
  width:34px;
  height:34px;
  border-radius:999px;
  border:1px solid rgba(242,166,191,.28);
  background:rgba(255,255,255,.55);
  color:rgba(31,36,48,.85);
  font-weight:900;
  font-size:14px;
  display:grid;
  place-items:center;
  cursor:pointer;
  box-shadow:none;
  opacity:.62;
}
.card-info:hover{
  opacity:.90;
  background:rgba(255,214,227,.55);
  border-color:rgba(242,166,191,.55);
}
@media (hover:none){
  .card-info{ opacity:.50; background:rgba(255,255,255,.45); }
  .card.is-open .card-info{ opacity:.95; background:rgba(255,214,227,.65); }
}

/* ========= パンくず ========= */
.breadcrumbs{
  display:flex;
  align-items:center;
  flex-wrap:wrap;
  gap:8px;
  color:rgba(31,36,48,.62);
  font-size:12px;
  padding:12px 0 6px;
}
.breadcrumbs .sep{ opacity:.55; }
.breadcrumbs .current{ color:rgba(31,36,48,.88); }

/* ========= 個別ページ ========= */
.post{ padding-top:10px; }
.post-header{ padding:14px 0 16px; }

/* ※上部カテゴリを消しても日付が右に張り付くようにする */
.post-topline{
  display:flex;
  align-items:center;
  justify-content:flex-end;
  gap:12px;
}

.post-title{
  margin:10px 0 0;
  font-size:24px;
  letter-spacing:.15px;
  line-height:1.25;
  color:rgba(31,36,48,.92);
}
.post-location{ margin:8px 0 0; color:rgba(31,36,48,.62); font-size:13px; }

/* PHOTO表示 */
.post-photo{
  margin:8px 0 0;
  display:inline-flex;
  align-items:center;
  gap:8px;
  font-size:12px;
  font-weight:900;
  letter-spacing:.4px;
  text-transform:uppercase;
  color:rgba(31,36,48,.78);
}
.post-photo::before{
  content:"";
  width:10px;
  height:10px;
  border-radius:999px;
  background:rgba(255,214,227,.85);
  border:1px solid rgba(242,166,191,.55);
  box-shadow:var(--shadow2);
}

/* ========= 画像ギャラリー（縦並び） ========= */
.post-gallery{
  display:flex;
  flex-direction:column;
  gap:16px;
  margin:18px 0 0;
}

.shot{
  margin:0;
  position:relative;
  border-radius:var(--radius);
  overflow:hidden;
  border:1px solid var(--line);
  background:rgba(255,255,255,.70);
  box-shadow:var(--shadow2);
}
.shot img{ width:100%; height:auto; }

/* キャプション（PC: hover/focus / スマホ: JSでis-open制御） */
.shot figcaption{
  position:absolute;
  left:10px;
  right:10px;
  bottom:10px;
  padding:10px 12px;
  border-radius:14px;
  background:rgba(255,255,255,.75);
  border:1px solid rgba(31,36,48,.10);
  backdrop-filter:blur(8px);
  color:rgba(31,36,48,.92);
  font-size:13px;
  line-height:1.55;
  opacity:0;
  transform:translateY(6px);
  transition:opacity .18s ease, transform .18s ease;
  pointer-events:none;
}
.shot:hover figcaption,
.shot:focus-within figcaption{ opacity:1; transform:translateY(0); }

@media (hover:none){
  .shot:hover figcaption,
  .shot:focus-within figcaption{ opacity:0; transform:translateY(6px); }
  .shot.is-open figcaption{ opacity:1; transform:translateY(0); }
}

.shot figcaption.cap{
  display:flex;
  gap:10px;
  align-items:baseline;
  justify-content:space-between;
}
.shot figcaption.cap .cap-text{
  flex:1;
  min-width:0;
  text-align:left;
  font-weight:700;
}
.shot figcaption.cap .cap-by{
  white-space:nowrap;
  text-align:right;
  font-size:11px;
  font-weight:900;
  color:rgba(31,36,48,.72);
}

/* ========= NOTE ========= */
.post-body{
  margin:18px 0 0;
  max-width:70ch;
  position:relative;
  background:rgba(255,255,255,.92);
  border:1px solid rgba(242,166,191,.42);
  border-left:6px solid rgba(242,166,191,.78);
  border-radius:var(--radius);
  padding:24px 16px 14px; /* NOTEラベル分 */
  box-shadow:var(--shadow2);
  color:rgba(31,36,48,.90);
}
.post-body::before{
  content:"NOTE";
  position:absolute;
  top:-10px;
  left:14px;
  padding:2px 8px;
  border-radius:999px;
  background:rgba(255,214,227,.80);
  border:1px solid rgba(242,166,191,.55);
  color:var(--accent-ink);
  font-size:11px;
  font-weight:900;
  letter-spacing:.5px;
}
.post-body p{ margin:0 0 12px; }

/* ========= 個別フッター（カテゴリ＋タグ） ========= */
.post-footer{
  margin-top:22px;
  padding-top:18px;
  border-top:1px solid var(--line);
}

.tags{ display:flex; flex-wrap:wrap; gap:8px; }

.tag.link{
  padding:.25rem .55rem;
  border-radius:999px;
  border:1px solid rgba(242,166,191,.35);
  background:rgba(255,214,227,.35);
  font-size:12px;
  color:rgba(31,36,48,.86);
}
.tag.link:hover{ background:rgba(255,214,227,.60); }

/* カテゴリは“タグと差が出る”見た目にする */
.tag.link.tag-cat{
  background:rgba(255,214,227,.65);
  border-color:rgba(242,166,191,.55);
  color:var(--accent-ink);
  font-weight:900;
}
.tag.link.tag-cat:hover{ background:rgba(255,214,227,.85); }

/* ========= アクション（いいね・シェア） ========= */
.post-actions{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
  margin-top:14px;
}
.like, .share-btn{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:10px 12px;
  border-radius:999px;
  border:1px solid rgba(242,166,191,.35);
  background:rgba(255,255,255,.92);
  color:rgba(31,36,48,.88);
  cursor:pointer;
  box-shadow:var(--shadow2);
}
.like:hover, .share-btn:hover{ background:rgba(255,214,227,.55); }

/* ========= 前後 ========= */
.post-nav{
  margin-top:16px;
  display:flex;
  gap:10px;
  justify-content:space-between;
}
.nav-item{
  flex:1;
  padding:12px 12px;
  border-radius:var(--radius);
  border:1px solid rgba(242,166,191,.25);
  background:rgba(255,255,255,.92);
  color:rgba(31,36,48,.88);
  box-shadow:var(--shadow2);
}
.nav-item:hover{ background:rgba(255,214,227,.45); }

/* ========= 関連 ========= */
.related{ margin-top:22px; }
.section-title{
  margin:0 0 12px;
  font-size:14px;
  letter-spacing:.15px;
  color:rgba(31,36,48,.90);
}
.grid-related .card{ min-height:210px; }

/* ========= 一覧（カテゴリ/タグ/PHOTO） ========= */
.taxo-grid{ display:flex; flex-wrap:wrap; gap:10px; }
.taxo-chip{
  display:inline-flex;
  align-items:center;
  gap:10px;
  padding:10px 12px;
  border-radius:999px;
  border:1px solid rgba(242,166,191,.28);
  background:rgba(255,255,255,.92);
  box-shadow:var(--shadow2);
  color:rgba(31,36,48,.90);
}
.taxo-chip:hover{
  background:rgba(255,214,227,.65);
  border-color:rgba(242,166,191,.55);
}
.taxo-name{
  font-weight:900;
  letter-spacing:.4px;
  text-transform:uppercase;
  font-size:12px;
}
.taxo-count{
  min-width:2.2em;
  text-align:center;
  padding:2px 8px;
  border-radius:999px;
  background:rgba(255,214,227,.70);
  border:1px solid rgba(242,166,191,.45);
  color:var(--accent-ink);
  font-size:12px;
  font-weight:900;
}

/* ========= いいね（アニメ） ========= */
.like{ position:relative; transform:translateZ(0); will-change:transform; }
.like.is-anim{
  animation:likePop 320ms ease-out;
  border-color:rgba(242,166,191,.70);
}
.like.is-anim::before{
  content:"";
  position:absolute;
  inset:-2px;
  border-radius:inherit;
  background:rgba(255,214,227,.55);
  opacity:0;
  animation:likeGlow 320ms ease-out;
  pointer-events:none;
}
.like .like-count.is-bump{ display:inline-block; animation:countBump 320ms ease-out; }

@keyframes likePop{
  0%{ transform:scale(1); }
  35%{ transform:scale(1.10); }
  70%{ transform:scale(0.98); }
  100%{ transform:scale(1); }
}
@keyframes likeGlow{
  0%{ opacity:0; transform:scale(0.98); }
  35%{ opacity:1; transform:scale(1); }
  100%{ opacity:0; transform:scale(1.02); }
}
@keyframes countBump{
  0%{ opacity:.9; transform:translateY(0); }
  35%{ opacity:1; transform:translateY(-4px); }
  100%{ opacity:1; transform:translateY(0); }
}

/* いいね：塗りつぶし＆飛ぶハート */
.like.is-liked{
  background:rgba(255,214,227,.80);
  border-color:rgba(242,166,191,.70);
  animation:likePop 320ms ease-out;
}
.like-heart-float{
  position:absolute;
  left:14px;
  top:50%;
  transform:translateY(-50%);
  font-size:14px;
  color:rgba(242,166,191,.95);
  pointer-events:none;
  will-change:transform, opacity;
  animation:heartFloat 700ms ease-out forwards;
  filter:drop-shadow(0 6px 10px rgba(31,36,48,.12));
}
@keyframes heartFloat{
  0%{ opacity:0; transform:translateY(-50%) translateX(0) scale(.9); }
  15%{ opacity:1; transform:translateY(-70%) translateX(2px) scale(1.05); }
  60%{ opacity:.9; transform:translateY(-105%) translateX(10px) scale(1.12); }
  100%{ opacity:0; transform:translateY(-140%) translateX(18px) scale(.95); }
}