/*
 * /plan/* 專用 layout。
 * 遵守視覺約束（見 spec「設計約束」章節）：
 *   - 僅使用 styles.css :root 的 CSS variable
 *   - 不得重新定義 :root、不得覆蓋 .hero__ / .board__ / .nav__ / .brand__
 *   - 禁止 hex colour、漸層、glow、新字型、新圓角值
 *
 * Navbar：styles.css 的 .nav__plan-cta pill 在所有斷點都顯示，
 * /plan/* 用 nav__plan-cta--return modifier 翻轉箭頭方向當「回程」CTA。
 * 手機上 nav__links 依舊隱藏（跟首頁一致），pill 本身就是主要行動。
 */

.plan {
  max-width: var(--w);
  margin: 0 auto;
  padding: 24px 16px 48px;
  font-family: var(--font-sans);
  color: var(--ink);
}

/* Hero — query-bar style：dark qbar + meta strip + body */
.plan__hero {
  margin-bottom: 32px;
  padding: 0;
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  overflow: hidden;
}
.plan__hero-body {
  padding: 22px 24px 24px;
}
.plan__breadcrumb {
  font-size: 13px;
  color: var(--ink-3);
  margin-bottom: 12px;
}
.plan__breadcrumb a { color: var(--ink-2); }
.plan__breadcrumb a:hover { color: var(--acc-ink); }
.plan h1 {
  font-family: var(--font-serif);
  font-size: 28px;
  line-height: 1.3;
  margin-bottom: 12px;
}
.plan__summary {
  font-size: 16px;
  color: var(--ink-2);
  margin-bottom: 12px;
}
.plan__intro {
  font-size: 14px;
  color: var(--ink-2);
  line-height: 1.7;
}

/* Segments */
.plan__segments { margin-bottom: 40px; }
.plan__segments h2 {
  font-family: var(--font-serif);
  font-size: 20px;
  margin-bottom: 16px;
}
.plan__segments-h2 {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: 12px;
  flex-wrap: wrap;
}
.plan__segments-h2__text { display: inline; }
.plan__segments-h2 .plan__column-date {
  font-size: 13px;
}
.plan__segment-list {
  display: grid;
  gap: 12px;
  list-style: none;
  padding: 0;
}
.plan__segment-card {
  padding: 16px;
  background: var(--bg-2);
  border: 1px solid var(--line);
  border-radius: var(--radius);
}
.plan__segment-head {
  display: flex;
  justify-content: space-between;
  font-family: var(--font-mono);
  font-size: 12.5px;
  color: var(--ink-3);
  margin-bottom: 8px;
}
.plan__segment-num { color: var(--acc-ink); font-weight: 700; }
.plan__segment-steps { margin: 0; }
.plan__segment-steps dt {
  font-family: var(--font-mono);
  font-size: 11.5px;
  color: var(--ink-3);
  text-transform: uppercase;
  margin-top: 8px;
}
.plan__segment-steps dd { margin: 0 0 4px 0; font-size: 14.5px; color: var(--ink); }
.plan__warnings { font-size: 12.5px; color: var(--warn); margin-top: 8px; }

/* Timetable columns */
.plan__timetables {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
  margin-bottom: 40px;
}
/* short-haul（台東車站／轉運站起點，無台鐵段）：只剩公車 + 富岡船班 2 欄 */
.plan__timetables--short-haul { grid-template-columns: repeat(2, 1fr); }
@media (max-width: 720px) {
  .plan__timetables { grid-template-columns: 1fr; }
  .plan__timetables--short-haul { grid-template-columns: 1fr; }
}
.plan__column {
  padding: 16px;
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: var(--radius);
}
.plan__column-title {
  font-family: var(--font-serif);
  font-size: 15px;
  margin-bottom: 12px;
  color: var(--ink);
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: 12px;
  flex-wrap: wrap;
}
.plan__column-title__text { display: inline; }
.plan__column-date {
  font-family: var(--font-mono);
  font-size: 12px;
  font-weight: normal;
  color: var(--ink-3);
  letter-spacing: 0.02em;
  white-space: nowrap;
}
.plan__timetable {
  list-style: none;
  padding: 0;
  margin: 0;
  display: grid;
  gap: 6px;
}
.plan__row {
  display: grid;
  grid-template-columns: auto 1fr auto;
  gap: 12px;
  align-items: center;
  padding: 8px 10px;
  border: 1px solid var(--line-2);
  border-radius: var(--radius-sm);
  background: var(--bg);
  font-size: 14px;
}
.plan__time {
  font-family: var(--font-mono);
  font-size: 13px;
  color: var(--ink);
}
.plan__time--arrive { color: var(--ink-3); }
.plan__label { color: var(--ink-2); }
.plan__empty {
  font-size: 13px;
  color: var(--ink-3);
  padding: 12px;
  text-align: center;
}

/* CTA */
.plan__cta {
  padding: 24px;
  background: var(--acc-bg);
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  margin-bottom: 32px;
  text-align: center;
}
.plan__cta h2 {
  font-family: var(--font-serif);
  font-size: 20px;
  color: var(--acc-ink);
  margin-bottom: 8px;
}
.plan__cta p { font-size: 14px; color: var(--ink-2); margin-bottom: 16px; }
.plan__cta-btn {
  display: inline-block;
  padding: 12px 20px;
  background: var(--acc);
  color: var(--bg);
  border-radius: 100px;
  font-weight: 700;
  text-decoration: none;
}
.plan__cta-btn:hover { background: var(--acc-ink); color: var(--bg); }

/* Footer */
.plan__footer {
  font-size: 12.5px;
  color: var(--ink-3);
  padding-top: 24px;
  border-top: 1px solid var(--line-2);
}

/* Hub (for /plan/) */
.plan__hub h2 { font-family: var(--font-serif); font-size: 20px; margin-bottom: 16px; }
.plan__hub-list {
  list-style: none;
  padding: 0;
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  gap: 12px;
}
.plan__hub-item a {
  display: block;
  padding: 16px;
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  text-decoration: none;
  color: var(--ink);
}
.plan__hub-item a:hover {
  border-color: var(--acc);
  color: var(--acc-ink);
}
.plan__hub-title { display: block; font-family: var(--font-serif); font-size: 16px; margin-bottom: 4px; }
.plan__hub-desc { display: block; font-size: 13px; color: var(--ink-3); }

/* Editorial 長文 */
.plan__editorial {
  margin-bottom: 32px;
  padding: 24px;
  background: var(--bg);
  border: 1px solid var(--line-2);
  border-radius: var(--radius);
  font-size: 15px;
  line-height: 1.8;
  color: var(--ink-2);
}
.plan__editorial p { margin: 0 0 12px 0; }
.plan__editorial p:last-child { margin-bottom: 0; }
.plan__editorial strong { color: var(--ink); }

/* Related 區塊 */
.plan__related {
  margin-top: 40px;
  padding-top: 24px;
  border-top: 1px solid var(--line-2);
}
.plan__related h2 { font-family: var(--font-serif); font-size: 18px; margin-bottom: 12px; }
.plan__related-list {
  list-style: none;
  padding: 0;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: 8px;
}
.plan__related-list a {
  display: block;
  padding: 10px 14px;
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: var(--radius-sm);
  font-size: 14px;
  color: var(--ink-2);
  text-decoration: none;
}
.plan__related-list a:hover { color: var(--acc-ink); border-color: var(--acc); }

/* ─────────────────────────────────────────────
 * Hero「query bar」：深色帶 + 大日期顯示 + 副標 meta strip
 *
 * qbar 是純顯示區（不含 input）—— `2026.04.26` 用 serif + mono `.sep` 自訂排版，
 * 是 native date input 受 system locale 限制做不出來的編輯感。換日 picker 在
 * 下方 .plan__date-pick 區。
 * ───────────────────────────────────────────── */
.plan__qbar {
  display: grid;
  grid-template-columns: auto 1fr;
  align-items: stretch;
  background: var(--ink);
  color: var(--bg);
}
.plan__qbar-label {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 14px 18px;
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: rgba(238, 242, 244, 0.55);
  border-right: 1px solid rgba(238, 242, 244, 0.1);
}
.plan__qbar-label svg {
  width: 16px;
  height: 16px;
  opacity: 0.8;
}
.plan__qbar-date {
  display: flex;
  align-items: center;
  padding: 14px 18px;
}
.plan__qbar-date time {
  font-family: var(--font-serif);
  font-weight: 900;
  font-size: clamp(28px, 4vw, 38px);
  line-height: 1;
  letter-spacing: -0.025em;
  color: #fff;
  font-variant-numeric: tabular-nums;
}
.plan__qbar-date time .sep {
  font-family: var(--font-mono);
  font-weight: 400;
  font-size: 0.5em;
  color: rgba(255, 255, 255, 0.55);
  vertical-align: 0.22em;
  margin: 0 0.1em;
  letter-spacing: 0;
}

/* meta strip：qbar 下方淡灰條，顯示週幾 · 距今 · N 段銜接 */
.plan__qbar-meta {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 12px;
  padding: 10px 18px;
  background: var(--bg-2);
  border-bottom: 1px solid var(--line);
  font-family: var(--font-mono);
  font-size: 12px;
  color: var(--ink-3);
  letter-spacing: 0.04em;
}
.plan__qbar-meta .dow { color: var(--ink); font-weight: 700; letter-spacing: 0.02em; }
.plan__qbar-meta .dot { color: var(--ink-3); opacity: 0.5; }
.plan__qbar-meta .rel { color: var(--ink-3); }
.plan__qbar-meta .seg { color: var(--acc-ink); font-weight: 700; }
.plan__qbar-meta .warn { color: var(--warn); }

.plan__date-hint {
  display: block;
  padding: 8px 18px;
  font-family: var(--font-mono);
  font-size: 12px;
  color: var(--acc-ink);
  background: var(--acc-bg);
  border-bottom: 1px solid var(--line);
}
.plan__date-hint[hidden] { display: none; }

/* 手機：藏 label 區 */
@media (max-width: 560px) {
  .plan__qbar { grid-template-columns: 1fr; }
  .plan__qbar-label { display: none; }
  .plan__qbar-date { padding: 16px 18px; }
}

/* ─────────────────────────────────────────────
 * 「換出發日」picker 區：label + 真·可見 native input
 *
 * Cross-browser-safe pattern：
 *   - iOS Safari：input 真·可見，user tap → 原生 picker 開
 *   - Chrome 桌機：點 input 文字本身「不」會開 picker，要點
 *     ::-webkit-calendar-picker-indicator pseudo——把 indicator 設為
 *     「絕對定位、透明、覆蓋整個 input」，用戶點任意處都命中。
 *     (plan-hydrate.js click handler 還有 showPicker() 兜第二層保險)
 *   - position:relative 確保 indicator 的 inset:0 相對 input 本身。
 * ───────────────────────────────────────────── */
.plan__date-pick {
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
  margin-top: 18px;
  padding-top: 16px;
  border-top: 1px solid var(--line-2);
}
.plan__date-pick__label {
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--ink-3);
  text-transform: uppercase;
  letter-spacing: 0.16em;
  cursor: pointer;
}
.plan__date-input {
  -webkit-appearance: none;
  appearance: none;
  background: var(--bg);
  border: 1.5px solid var(--ink-3);
  border-radius: var(--radius-sm);
  padding: 8px 14px;
  margin: 0;
  font-family: var(--font-mono);
  font-size: 14px;
  color: var(--ink);
  -webkit-text-fill-color: var(--ink);
  cursor: pointer;
  font-variant-numeric: tabular-nums;
  position: relative;
  min-height: 0;
  transition: border-color 140ms ease, background 140ms ease;
}
.plan__date-input:hover,
.plan__date-input:focus,
.plan__date-input:focus-within {
  border-color: var(--acc);
  background: var(--acc-bg);
  outline: none;
}
.plan__date-input:focus-visible { outline: 2px solid var(--acc); outline-offset: 2px; }
.plan__date-input::-webkit-date-and-time-value {
  text-align: left;
  padding: 0;
  margin: 0;
}
/* 透明覆蓋整個 input，Chrome 點 input 任意處 → 命中 indicator → 開 picker */
.plan__date-input::-webkit-calendar-picker-indicator {
  -webkit-appearance: none;
  appearance: none;
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  margin: 0;
  padding: 0;
  background: transparent;
  color: transparent;
  cursor: pointer;
}
.plan__date-input::-webkit-inner-spin-button,
.plan__date-input::-webkit-clear-button { display: none; }

/* ─────────────────────────────────────────────
 * 銜接 card 內「船班」dd 的 ferry.tw 訂票連結
 *   「09:30 → 10:20 ↗」default ink + dotted underline；hover 切到 acc-ink
 * ───────────────────────────────────────────── */
.plan__seg-ferry-time {
  color: var(--ink);
  text-decoration: none;
  border-bottom: 1px dotted var(--line);
  padding-bottom: 1px;
  transition: color 120ms ease, border-color 120ms ease;
}
.plan__seg-ferry-arrow {
  display: inline-block;
  margin-left: 4px;
  font-family: var(--font-mono);
  font-size: 0.92em;
  color: var(--ink-3);
  transition: color 120ms ease, transform 120ms ease;
}
.plan__seg-ferry-time:hover {
  color: var(--acc-ink);
  border-bottom-color: var(--acc-ink);
}
.plan__seg-ferry-time:hover .plan__seg-ferry-arrow {
  color: var(--acc-ink);
  transform: translate(1px, -1px);
}
