/* ==========================================
   patrol.css 安全版
   目的：
   - 装飾は維持
   - 崩れや競合の原因になる重複のみ整理
   - 一覧 / 詳細 / ギャラリーのスコープ競合を明確化

   保留にしたもの：
   1) PATROLラベル装飾（::before）
      - 現行デザインとして維持

   2) clip-path / overflow の角丸維持処理
      - 現行見た目維持のため残す

   3) hero の演出値
      - 最終的に効いている値を採用
   ========================================== */


/* ===============================
   1) ページ変数
   =============================== */

/* パトロール一覧 */
body.page-patrol {
  --hero-anim: hero-zoomfade;
  --hero-duration: 2.4s;
  --hero-scale-start: 1.06;
  --hero-gray-start: 100%;
  --hero-bright-start: 0.92;
  --cap-delay: 0.9s;
}

/* パトロール詳細 */
body.page-patrol-detail {
  --hero-anim: hero-zoomfade;
  --hero-duration: 1.8s;
  --hero-scale-start: 1.04;
  --hero-gray-start: 80%;
  --hero-bright-start: 1.08;
  --cap-delay: 0.9s;
}


/* ===============================
   2) hero
   =============================== */

body.page-patrol .top-img .cap {
  bottom: 8%;
}

body.page-patrol .top-img .cap-bg {
  padding: clamp(10px, 1.4vw, 14px) clamp(14px, 2vw, 20px);
  border-radius: 12px;
  background: rgba(17,24,39,.58);
  backdrop-filter: saturate(140%) blur(2px);
}


/* ===============================
   3) PATROL PAGE
   patrol.html 専用
   =============================== */

/* ---- intro ---- */
.page-patrol .patrol-intro {
  width: 100%;
  max-width: none;
  margin: 30px 0 36px;
}

.page-patrol .patrol-intro p {
  margin: 0;
  font-size: 18px;
  line-height: 2;
  text-align: justify;
  text-justify: inter-ideograph;
}

/* ---- 年タイトル帯 ---- */
.page-patrol .title-band {
  margin: 30px 0 24px;
  text-align: left;
  padding: 10px 14px;
  background: #fff;
  border: 1px solid #e5e7eb;
  border-left: 6px solid #60a5fa;
  border-radius: 8px;
}

.page-patrol .title-band h2 {
  margin: 0;
  font-size: 26px;
  font-weight: 700;
}

.page-patrol .title-band .year {
  margin-right: 6px;
  color: #1e40af;
}

/* ---- patrol grid ---- */
.page-patrol .patrol-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 24px;
  margin-top: 24px;
}

/* ---- card ---- */
.page-patrol .patrol-item {
  position: relative;
  border: none;
  border-radius: 20px;
  background: #fff;
  box-shadow: 0 4px 14px rgba(2,6,23,.06);
  overflow: visible;
  clip-path: inset(0 round 20px);
  transition: transform .25s ease, box-shadow .25s ease;
}

.page-patrol .patrol-item:hover {
  transform: translateY(-3px);
  box-shadow: 0 12px 28px rgba(2,6,23,.12);
  clip-path: inset(0 round 20px);
}

.page-patrol .patrol-link {
  display: block;
  text-decoration: none;
  color: inherit;
}

.page-patrol .patrol-item .thumb {
  aspect-ratio: 4 / 3;
  overflow: hidden;
  border-top-left-radius: 20px;
  border-top-right-radius: 20px;
  background: #fff;
}

.page-patrol .patrol-item .thumb img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  transform: scale(1);
  transition: transform .4s ease;
  border-radius: 0;
}

.page-patrol .patrol-item:hover .thumb img {
  transform: scale(1.06);
}

.page-patrol .patrol-item .caption {
  padding: 14px 16px 18px;
  text-align: center;
  background: linear-gradient(180deg, #fff 0%, #f8fafc 100%);
}

.page-patrol .patrol-item .caption .date {
  font-size: 13px;
  color: #334155;
  margin-bottom: 4px;
}

.page-patrol .patrol-item .caption .title {
  font-weight: 700;
  font-size: 1rem;
  color: #1f2937;
  margin: 0 0 4px;
  text-align: center;
}

/* PATROL ラベル */
.page-patrol .patrol-item::before {
  content: "PATROL";
  position: absolute;
  top: 10px;
  left: 10px;
  z-index: 2;
  background: rgba(37,99,235,0.9);
  color: #fff;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: .05em;
  padding: 4px 8px;
  border-top-left-radius: 8px;
  border-bottom-right-radius: 6px;
  box-shadow: 0 0 0 6px #fff;
}

/* ---- bottom action ---- */
.page-patrol .section-actions {
  display: flex;
  justify-content: center;
  grid-column: 1 / -1;
  margin: 20px 0;
  text-align: center;
}

.page-patrol .section-actions .btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 15px;
  padding: 5px 18px;
  border-radius: 9999px;
  font-size:18px;
  font-weight: 400;
  text-decoration: none;
  cursor: pointer;
  transition: background .2s, transform .1s, color .2s, border-color .2s;
}

.page-patrol .section-actions .btn.btn-outline {
  border: 1px solid #2563eb;
  color: #2563eb;
  background: #fff;
}

.page-patrol .section-actions .btn.btn-outline:hover {
  background: #eff6ff;
  transform: translateY(-1px);
}

/* ---- breadcrumb ---- */
.page-patrol .breadcrumb {
  font-size: 14px;
  color: #475569;
  margin: 16px auto 0;
}

.page-patrol .breadcrumb a {
  color: inherit;
  text-decoration: none;
}

.page-patrol .breadcrumb .sep {
  margin: 0 6px;
  color: #94a3b8;
}

/* ---- responsive ---- */
@media (max-width: 900px) {
  .page-patrol .patrol-grid {
    grid-template-columns: repeat(2, minmax(0,1fr));
  }
}

@media (max-width: 640px) {
  .page-patrol .patrol-intro {
    margin: 24px 0 30px;
  }

  .page-patrol .patrol-intro p {
    font-size: 15px;
    line-height: 1.9;
  }

  .page-patrol .title-band {
    margin: 24px 0 20px;
    text-align: left;
  }

  .page-patrol .title-band h2 {
    font-size: 22px;
  }

  .page-patrol .patrol-grid {
    grid-template-columns: 1fr;
    gap: 18px;
  }
}


/* ===============================
   4) PATROL DETAIL
   =============================== */

.page-patrol .patrol-detail {
  margin-top: 32px;
}

.page-patrol .detail-head {
  display: flex;
  align-items: center;
  gap: 12px;
  background: linear-gradient(90deg,#eef6ff 0%,#ffffff 46%);
  border: 1px solid #e6effe;
  border-left: 6px solid #60a5fa;
  border-radius: 12px;
  padding: 10px 16px;
  margin: 0 0 12px;
  box-shadow: none;
}

.page-patrol .detail-head .eyebrow {
  display: inline-block;
  font-size: 16px;
  letter-spacing: .08em;
  font-weight: 700;
  color: #475569;
  background: #f8fafc;
  border: 1px solid #e2e8f0;
  border-radius: 999px;
  padding: 4px 10px 3px;
  line-height: 1;
  white-space: nowrap;
  margin: 0;
}

.page-patrol .detail-head .date {
  margin: 0;
  font-size: clamp(18px, 2.8vw, 22px);
  font-weight: 800;
  color: #0f172a;
  line-height: 1.4;
}

.page-patrol .detail-meta {
  display: block;
  margin: 10px 0 0;
}

.page-patrol .detail-meta > div {
  display: block;
}

.page-patrol .detail-meta dt {
  display: none;
}

.page-patrol .detail-meta dd {
  margin: 0;
}

.page-patrol .detail-desc {
  font-size: 16.5px;
  line-height: 1.9;
  max-width: 60ch;
  color: #334155;
}


/* ===============================
   5) PHOTO GALLERY
   =============================== */

.page-patrol .patrol-photos {
  margin-top: 28px;
}

.page-patrol .sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0,0,0,0);
  border: 0;
}

.page-patrol .gallery {
  list-style: none;
  padding: 0;
  margin: 0;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
}

.page-patrol .gallery .item a {
  display: block;
  text-decoration: none;
  color: inherit;
}

.page-patrol .gallery .thumb {
  aspect-ratio: 4 / 3;
  background: #f8fafc;
  overflow: hidden;
  border-radius: 10px;
  box-shadow: 0 2px 8px rgba(2,6,23,.04);
}

.page-patrol .gallery .thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform .25s ease;
}

.page-patrol .gallery .item a:hover .thumb img {
  transform: scale(1.06);
}

.page-patrol .gallery .item a:hover .thumb {
  outline: 2px solid #93c5fd;
  outline-offset: -2px;
  box-shadow: 0 10px 24px rgba(2,6,23,.08);
}

.page-patrol .gallery figcaption {
  font-size: 13px;
  color: #64748b;
  margin-top: 6px;
  text-align: center;
}

.page-patrol .photo-note {
  margin-top: 12px;
  font-size: 13px;
  color: #64748b;
}

@media (max-width: 960px) {
  .page-patrol .gallery {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 600px) {
  .page-patrol .gallery {
    grid-template-columns: 1fr;
  }

  .page-patrol .detail-head {
    align-items: flex-start;
    flex-direction: column;
    gap: 8px;
  }

  .page-patrol .date {
    font-size: 20px;
  }
}


/* ===============================
   6) 戻るボタン
   =============================== */

.page-patrol .back {
  margin: 28px auto 40px;
  text-align: center;
}

.page-patrol .btn-back {
  display: inline-block;
  padding: 10px 18px;
  border: 1px solid #cbd5e1;
  border-radius: 999px;
  text-decoration: none;
  color: #0f172a;
  transition: background .2s ease, border-color .2s ease;
}

.page-patrol .btn-back:hover {
  background: #eef6ff;
  border-color: #93c5fd;
}

