/* ========================================================
   皮克敏親子部落格 — 全站樣式
   配色參考：皮克敏系列（草地綠、探索橘、泥土棕）
   ======================================================== */

:root {
  /* 皮克敏主色系 */
  --green-dark:    #2C6B2F;
  --green-mid:     #3D8B37;
  --green-light:   #6DB33F;
  --green-pale:    #EAF5E0;
  --green-bg:      #F2FAF0;

  /* 皮克敏角色色 */
  --pikmin-red:    #D94040;
  --pikmin-yellow: #E8B800;
  --pikmin-blue:   #2F69C2;
  --pikmin-purple: #7B4FBF;
  --pikmin-white:  #9BBABA;
  --pikmin-rock:   #6B5B3E;
  --pikmin-winged: #E87BBF;
  --pikmin-ice:    #5BBCE8;

  /* 文字 */
  --text-dark:     #1A2F1A;
  --text-mid:      #3D5C3D;
  --text-light:    #5C7A5C;
  --text-muted:    #8AAA8A;

  /* 卡片 / UI */
  --card-bg:       #FFFFFF;
  --card-border:   #D4E8C8;
  --card-shadow:   0 2px 14px rgba(44, 107, 47, 0.10);
  --card-hover:    0 6px 28px rgba(44, 107, 47, 0.18);

  /* 標籤 */
  --tag-discover:  #2F69C2;
  --tag-family:    #D94040;
  --tag-tips:      #E8B800;
  --tag-schedule:  #7B4FBF;

  /* 間距 */
  --space-xs:  4px;
  --space-s:   8px;
  --space-m:   16px;
  --space-l:   24px;
  --space-xl:  40px;
  --space-2xl: 64px;

  /* 字型 */
  --font-base: 'Noto Sans TC', 'Microsoft JhengHei', sans-serif;
  --font-size-base: 16px;
  --line-height: 1.8;

  /* 圓角 */
  --radius-s:  6px;
  --radius-m:  12px;
  --radius-l:  20px;
  --radius-pill: 999px;

  /* 動畫 */
  --transition: 0.2s ease;
}

/* ── Reset ── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

html {
  scroll-behavior: smooth;
  font-size: var(--font-size-base);
}

body {
  font-family: var(--font-base);
  color: var(--text-dark);
  background: var(--green-bg);
  line-height: var(--line-height);
  overflow-x: hidden;
}

img { display: block; max-width: 100%; height: auto; }
a   { color: var(--green-mid); text-decoration: none; }
a:hover { text-decoration: underline; }

/* ── 頂部導覽 ── */
.site-nav {
  position: sticky;
  top: 0;
  z-index: 100;
  background: var(--green-dark);
  box-shadow: 0 2px 8px rgba(0,0,0,0.2);
}
.site-nav-inner {
  max-width: 1100px;
  margin: 0 auto;
  padding: var(--space-m) var(--space-l);
  display: flex;
  align-items: center;
  gap: var(--space-m);
}
.site-logo {
  color: #fff;
  font-size: 1.1rem;
  font-weight: 700;
  text-decoration: none;
  display: flex;
  align-items: center;
  gap: var(--space-s);
  flex-shrink: 0;
}
.site-logo:hover { text-decoration: none; opacity: 0.9; }
.site-logo-icon { font-size: 1.4rem; }

/* ── Hero ── */
.hero {
  position: relative;
  background: var(--green-dark);
  overflow: hidden;
  min-height: 420px;
  display: flex;
  align-items: center;
}
.hero-img-wrap {
  position: absolute;
  inset: 0;
}
.hero-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center top;
  opacity: 0.45;
}
.hero-inner {
  position: relative;
  z-index: 2;
  max-width: 1100px;
  margin: 0 auto;
  padding: var(--space-2xl) var(--space-l);
  text-align: center;
}
.hero-kicker {
  display: inline-block;
  background: var(--pikmin-yellow);
  color: var(--text-dark);
  font-size: 0.8rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  padding: 3px 12px;
  border-radius: var(--radius-pill);
  margin-bottom: var(--space-m);
}
.hero h1 {
  font-size: clamp(1.8rem, 5vw, 3rem);
  font-weight: 900;
  color: #fff;
  line-height: 1.3;
  text-shadow: 0 2px 8px rgba(0,0,0,0.4);
  margin-bottom: var(--space-m);
}
.hero-sub {
  font-size: clamp(0.95rem, 2vw, 1.15rem);
  color: rgba(255,255,255,0.88);
  max-width: 540px;
  margin: 0 auto var(--space-l);
  text-shadow: 0 1px 4px rgba(0,0,0,0.3);
}
.hero-counter {
  display: inline-flex;
  align-items: center;
  gap: var(--space-s);
  background: rgba(255,255,255,0.15);
  border: 1px solid rgba(255,255,255,0.3);
  color: #fff;
  font-size: 0.9rem;
  padding: var(--space-s) var(--space-l);
  border-radius: var(--radius-pill);
  backdrop-filter: blur(6px);
}
.hero-counter .view-count { font-weight: 700; color: var(--pikmin-yellow); }

/* ── 段落導覽標籤 ── */
.section-nav {
  position: sticky;
  top: 54px;
  z-index: 90;
  background: #fff;
  border-bottom: 2px solid var(--card-border);
  box-shadow: 0 2px 6px rgba(0,0,0,0.05);
}
.section-nav-inner {
  max-width: 1100px;
  margin: 0 auto;
  padding: 6px var(--space-l);
  display: flex;
  gap: var(--space-s);
  justify-content: center;
  flex-wrap: wrap;
}


.nav-tag {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 10px 18px;
  font-size: 0.88rem;
  font-weight: 700;
  color: var(--text-mid);
  border-bottom: 3px solid transparent;
  white-space: nowrap;
  text-decoration: none;
  transition: color var(--transition), border-color var(--transition);
  flex-shrink: 0;
}
.nav-tag:hover { text-decoration: none; }
.nav-tag.tag-discover { color: var(--tag-discover); }
.nav-tag.tag-discover:hover,
.nav-tag.tag-discover.active { border-bottom-color: var(--tag-discover); }
.nav-tag.tag-family  { color: var(--tag-family); }
.nav-tag.tag-family:hover,
.nav-tag.tag-family.active  { border-bottom-color: var(--tag-family); }
.nav-tag.tag-tips    { color: var(--tag-tips); }
.nav-tag.tag-tips:hover,
.nav-tag.tag-tips.active    { border-bottom-color: var(--tag-tips); }
.nav-tag.tag-schedule { color: var(--tag-schedule); }
.nav-tag.tag-schedule:hover,
.nav-tag.tag-schedule.active { border-bottom-color: var(--tag-schedule); }

/* ── 文章區段 ── */
.article-section {
  padding: var(--space-2xl) 0 var(--space-xl);
}
.article-section + .article-section {
  padding-top: 0;
}
.section-inner {
  max-width: 1100px;
  margin: 0 auto;
  padding: 0 var(--space-l);
}
.section-title {
  font-size: 1.5rem;
  font-weight: 800;
  color: var(--green-dark);
  margin-bottom: var(--space-l);
  display: flex;
  align-items: center;
  gap: var(--space-s);
}
.section-title::before {
  content: '';
  display: block;
  width: 5px;
  height: 1.4em;
  border-radius: var(--radius-pill);
  flex-shrink: 0;
}
.section-discover .section-title::before { background: var(--tag-discover); }
.section-family   .section-title::before { background: var(--tag-family); }
.section-tips     .section-title::before { background: var(--tag-tips); }
.section-schedule .section-title::before { background: var(--tag-schedule); }

/* ── 文章卡片格線 ── */
.cards-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
  gap: var(--space-l);
}

/* ── 卡片 ── */
.card {
  background: var(--card-bg);
  border: 1px solid var(--card-border);
  border-radius: var(--radius-m);
  box-shadow: var(--card-shadow);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  transition: box-shadow var(--transition), transform var(--transition);
}
.card:hover {
  box-shadow: var(--card-hover);
  transform: translateY(-3px);
}
.card-body { padding: var(--space-l); flex: 1; display: flex; flex-direction: column; }
.card-tags { display: flex; gap: var(--space-xs); flex-wrap: wrap; margin-bottom: var(--space-s); }

.tag-pill {
  font-size: 0.72rem;
  font-weight: 700;
  padding: 2px 10px;
  border-radius: var(--radius-pill);
  letter-spacing: 0.04em;
}
.tag-pill.discover { background: #E8EFFF; color: var(--tag-discover); }
.tag-pill.family   { background: #FFEAEA; color: var(--tag-family); }
.tag-pill.tips     { background: #FFF8DC; color: #8B6A00; }
.tag-pill.schedule { background: #F0E8FF; color: var(--tag-schedule); }

.card-title {
  font-size: 1.05rem;
  font-weight: 800;
  color: var(--text-dark);
  line-height: 1.5;
  margin-bottom: var(--space-s);
}
.card-excerpt {
  font-size: 0.88rem;
  color: var(--text-mid);
  line-height: 1.7;
  flex: 1;
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.card-meta {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-top: var(--space-m);
  padding-top: var(--space-m);
  border-top: 1px solid var(--card-border);
  font-size: 0.8rem;
  color: var(--text-muted);
  gap: var(--space-s);
  flex-wrap: wrap;
}
.card-meta-left  { display: flex; align-items: center; gap: var(--space-m); }
.card-date       { display: flex; align-items: center; gap: 4px; }
.card-views      { display: flex; align-items: center; gap: 4px; }
.card-link {
  margin-top: var(--space-m);
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: var(--green-mid);
  color: #fff;
  font-size: 0.85rem;
  font-weight: 700;
  padding: 8px 18px;
  border-radius: var(--radius-pill);
  text-decoration: none;
  transition: background var(--transition);
  align-self: flex-start;
}
.card-link:hover { background: var(--green-dark); text-decoration: none; }

/* ── 文章頁：頂部導覽列 ── */
.article-topnav {
  background: var(--green-dark);
  padding: var(--space-m) var(--space-l);
}
.article-topnav-inner {
  max-width: 780px;
  margin: 0 auto;
  display: flex;
  align-items: center;
  gap: var(--space-s);
}
.back-link {
  color: rgba(255,255,255,0.85);
  font-size: 0.9rem;
  text-decoration: none;
  display: flex;
  align-items: center;
  gap: 4px;
}
.back-link:hover { color: #fff; text-decoration: none; }
.breadcrumb-sep { color: rgba(255,255,255,0.4); }
.breadcrumb-current { color: rgba(255,255,255,0.6); font-size: 0.88rem; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }

/* ── 文章頁：主內容 ── */
.article-main {
  max-width: 780px;
  margin: 0 auto;
  padding: var(--space-xl) var(--space-l) var(--space-2xl);
}

/* 文章 Hero 圖片 */
.article-hero {
  margin-bottom: var(--space-xl);
  border-radius: var(--radius-m);
  overflow: hidden;
  box-shadow: var(--card-shadow);
}
.article-hero-img {
  width: 100%;
  max-width: 100%;
  height: auto;
  display: block;
}

/* 作者、日期、閱讀數（放內容最前面） */
.article-meta {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--space-m);
  padding: var(--space-m) var(--space-l);
  background: var(--green-pale);
  border-left: 4px solid var(--green-mid);
  border-radius: 0 var(--radius-m) var(--radius-m) 0;
  margin-bottom: var(--space-xl);
  font-size: 0.88rem;
  color: var(--text-mid);
}
.article-meta-item {
  display: flex;
  align-items: center;
  gap: 6px;
}
.article-meta-item strong { color: var(--green-dark); }

.article-title {
  font-size: clamp(1.5rem, 4vw, 2.1rem);
  font-weight: 900;
  color: var(--text-dark);
  line-height: 1.35;
  margin-bottom: var(--space-xl);
}

/* 文章內文 */
.article-content h2 {
  font-size: 1.3rem;
  font-weight: 800;
  color: var(--green-dark);
  margin: var(--space-xl) 0 var(--space-m);
  padding-left: var(--space-m);
  border-left: 4px solid var(--green-light);
}
.article-content h3 {
  font-size: 1.05rem;
  font-weight: 700;
  color: var(--text-dark);
  margin: var(--space-l) 0 var(--space-s);
}
.article-content p  { margin-bottom: var(--space-m); }
.article-content ul,
.article-content ol {
  margin: 0 0 var(--space-m) var(--space-l);
}
.article-content li { margin-bottom: var(--space-s); }
.article-content strong { color: var(--green-dark); }
.article-content em    { color: var(--text-mid); font-style: normal; background: #FFF8DC; padding: 0 4px; border-radius: 3px; }

/* 提示框 */
.tip-box {
  background: var(--green-pale);
  border: 1px solid var(--card-border);
  border-left: 4px solid var(--green-mid);
  border-radius: 0 var(--radius-m) var(--radius-m) 0;
  padding: var(--space-l);
  margin: var(--space-l) 0;
}
.tip-box h4 {
  font-size: 0.9rem;
  font-weight: 700;
  color: var(--green-dark);
  margin-bottom: var(--space-s);
  display: flex;
  align-items: center;
  gap: 6px;
}

/* 表格 */
.article-content table {
  width: 100%;
  border-collapse: collapse;
  margin: var(--space-l) 0;
  font-size: 0.9rem;
}
.article-content th {
  background: var(--green-dark);
  color: #fff;
  padding: var(--space-s) var(--space-m);
  text-align: left;
  font-weight: 700;
}
.article-content td {
  padding: var(--space-s) var(--space-m);
  border-bottom: 1px solid var(--card-border);
}
.article-content tr:nth-child(even) td { background: var(--green-pale); }

/* ── Footer ── */
.site-footer {
  background: var(--green-dark);
  color: rgba(255,255,255,0.75);
  padding: var(--space-xl) 0 var(--space-l);
  margin-top: var(--space-2xl);
}
.footer-inner {
  max-width: 1100px;
  margin: 0 auto;
  padding: 0 var(--space-l);
}
.footer-credit {
  font-size: 0.82rem;
  line-height: 1.7;
  margin-bottom: var(--space-l);
  padding: var(--space-m);
  background: rgba(255,255,255,0.07);
  border-radius: var(--radius-m);
  border: 1px solid rgba(255,255,255,0.1);
}
.footer-credit p { margin-bottom: 4px; }
.footer-credit a {
  color: var(--pikmin-yellow);
  text-decoration: underline;
}
.footer-credit a:hover { color: #fff; }
.footer-copy {
  font-size: 0.8rem;
  text-align: center;
  opacity: 0.6;
}

/* ── 返回頂部 ── */
.back-to-top {
  position: fixed;
  bottom: var(--space-l);
  right: var(--space-l);
  width: 44px;
  height: 44px;
  background: var(--green-mid);
  color: #fff;
  border: none;
  border-radius: 50%;
  font-size: 1.2rem;
  cursor: pointer;
  display: none;
  align-items: center;
  justify-content: center;
  box-shadow: 0 3px 12px rgba(0,0,0,0.2);
  transition: background var(--transition);
  z-index: 200;
}
.back-to-top.visible { display: flex; }
.back-to-top:hover { background: var(--green-dark); }

/* ── 骨架載入 ── */
.skeleton {
  background: linear-gradient(90deg, #e8f0e8 25%, #d4e4d4 50%, #e8f0e8 75%);
  background-size: 200% 100%;
  animation: shimmer 1.4s infinite;
  border-radius: var(--radius-s);
}
@keyframes shimmer {
  0%   { background-position: -200% 0; }
  100% { background-position:  200% 0; }
}

/* ── 響應式 ── */
@media (max-width: 768px) {
  :root {
    --space-l: 16px;
    --space-xl: 28px;
    --space-2xl: 44px;
  }
  .hero { min-height: 320px; }
  .cards-grid { grid-template-columns: 1fr; }
  .article-meta { flex-direction: column; align-items: flex-start; gap: var(--space-s); }
  .site-nav-inner { padding: var(--space-s) var(--space-m); }
}

@media (max-width: 480px) {
  .hero h1 { font-size: 1.5rem; }
  .hero-counter { font-size: 0.82rem; padding: var(--space-s) var(--space-m); }
  .card-meta { flex-direction: column; align-items: flex-start; }
}

/* ========================================================
   兒童友善設計系統 — 動畫、圖卡、視覺化元件
   ======================================================== */

/* ── 動畫 Keyframes ── */
@keyframes float {
  0%, 100% { transform: translateY(0); }
  50%       { transform: translateY(-10px); }
}
@keyframes float2 {
  0%, 100% { transform: translateY(0) rotate(-2deg); }
  50%       { transform: translateY(-8px) rotate(2deg); }
}
@keyframes pop-in {
  0%   { transform: scale(0.7); opacity: 0; }
  70%  { transform: scale(1.08); }
  100% { transform: scale(1); opacity: 1; }
}
@keyframes pulse-glow {
  0%, 100% { box-shadow: 0 0 0 0 rgba(61,139,55,0.35); }
  50%       { box-shadow: 0 0 0 10px rgba(61,139,55,0); }
}
@keyframes bounce-badge {
  0%, 100% { transform: scale(1); }
  30%       { transform: scale(1.12); }
  60%       { transform: scale(0.96); }
}
@keyframes slide-right {
  from { opacity: 0; transform: translateX(-20px); }
  to   { opacity: 1; transform: translateX(0); }
}

/* ── 捲動淡入動畫（需 JS 才觸發，NoJS 時直接可見） ── */
.js-enabled .anim {
  opacity: 0;
  transform: translateY(22px);
  transition: opacity 0.55s ease, transform 0.55s ease;
}
.js-enabled .anim.visible { opacity: 1; transform: translateY(0); }
.js-enabled .anim-d1 { transition-delay: 0.08s; }
.js-enabled .anim-d2 { transition-delay: 0.16s; }
.js-enabled .anim-d3 { transition-delay: 0.24s; }
.js-enabled .anim-d4 { transition-delay: 0.32s; }
.js-enabled .anim-d5 { transition-delay: 0.40s; }
.js-enabled .anim-d6 { transition-delay: 0.48s; }

/* ── 段落背景 ── */
.section-discover { background: linear-gradient(180deg, #EEF5FF 0%, #F2FAF0 100%); }
.section-family   { background: linear-gradient(180deg, #FFF3F3 0%, #F2FAF0 100%); }
.section-tips     { background: linear-gradient(180deg, #FFFCE0 0%, #F2FAF0 100%); }
.section-schedule { background: linear-gradient(180deg, #F6F0FF 0%, #F2FAF0 100%); }

/* ── 段落小標題 ── */
.subsection-title {
  font-size: 1.1rem;
  font-weight: 900;
  color: var(--green-dark);
  margin: var(--space-xl) 0 var(--space-m);
  display: flex;
  align-items: center;
  gap: 8px;
}
.subsection-title::after {
  content: '';
  flex: 1;
  height: 2px;
  background: var(--card-border);
  border-radius: 1px;
}

/* ── 皮克敏角色圖卡 ── */
.pikmin-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
  margin: 0 0 var(--space-l);
}
@media (max-width: 540px) { .pikmin-grid { grid-template-columns: repeat(2, 1fr); } }

.pikmin-card {
  background: #fff;
  border-radius: 20px;
  padding: 20px 10px 16px;
  text-align: center;
  border: 3px solid;
  transition: transform 0.22s, box-shadow 0.22s;
  cursor: default;
  user-select: none;
}
.pikmin-card:hover { transform: translateY(-6px) scale(1.04); box-shadow: 0 12px 28px rgba(0,0,0,0.14); }
.pikmin-card .p-dot {
  width: 14px; height: 14px;
  border-radius: 50%;
  margin: 0 auto 14px;
  opacity: 0.7;
}
.pikmin-card.p-red    .p-dot { background: #D94040; }
.pikmin-card.p-yellow .p-dot { background: #D4A017; }
.pikmin-card.p-blue   .p-dot { background: #2F69C2; }
.pikmin-card.p-ice    .p-dot { background: #3BB8D8; }
.pikmin-card.p-purple .p-dot { background: #7B4FBF; }
.pikmin-card.p-oatchi .p-dot { background: #E07020; }
.pikmin-card .p-name { font-weight: 900; font-size: 1.3rem; display: block; margin-bottom: 12px; line-height: 1.2; }
.pikmin-card .p-skill { font-size: 0.92rem; line-height: 1.85; color: var(--text-mid); display: block; }

.pikmin-card.p-red    { border-color: #D94040; background: #FFF4F4; }
.pikmin-card.p-red    .p-emoji { animation-delay: 0s; }
.pikmin-card.p-red    .p-name  { color: #D94040; }
.pikmin-card.p-yellow { border-color: #D4A017; background: #FFFCE0; }
.pikmin-card.p-yellow .p-emoji { animation-delay: 0.3s; }
.pikmin-card.p-yellow .p-name  { color: #9B7000; }
.pikmin-card.p-blue   { border-color: #2F69C2; background: #EFF5FF; }
.pikmin-card.p-blue   .p-emoji { animation-delay: 0.6s; }
.pikmin-card.p-blue   .p-name  { color: #2F69C2; }
.pikmin-card.p-ice    { border-color: #3BB8D8; background: #EFF9FF; }
.pikmin-card.p-ice    .p-emoji { animation-delay: 0.9s; }
.pikmin-card.p-ice    .p-name  { color: #1A90B0; }
.pikmin-card.p-purple { border-color: #7B4FBF; background: #F6F0FF; }
.pikmin-card.p-purple .p-emoji { animation-delay: 1.2s; }
.pikmin-card.p-purple .p-name  { color: #7B4FBF; }
.pikmin-card.p-oatchi { border-color: #E07020; background: #FFF4E8; }
.pikmin-card.p-oatchi .p-emoji { animation-delay: 1.5s; }
.pikmin-card.p-oatchi .p-name  { color: #C05010; }

/* ── 步驟圖卡 ── */
.step-cards {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(155px, 1fr));
  gap: 14px;
  margin: 0 0 var(--space-l);
}
.step-card {
  background: #fff;
  border-radius: 18px;
  padding: 22px 14px 18px;
  text-align: center;
  border-top: 5px solid;
  box-shadow: 0 4px 16px rgba(0,0,0,0.08);
  transition: transform 0.22s;
}
.step-card:hover { transform: translateY(-5px); }
.step-num {
  width: 38px; height: 38px;
  color: #fff;
  font-size: 1.1rem; font-weight: 900;
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  margin: 0 auto 12px;
}
.step-emoji { font-size: 2.2rem; display: block; margin-bottom: 10px; }
.step-title { font-weight: 800; font-size: 0.95rem; margin-bottom: 6px; color: var(--text-dark); }
.step-desc  { font-size: 0.8rem; color: var(--text-mid); line-height: 1.65; }

/* ── 理由圖卡 ── */
.reason-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
  gap: 13px;
  margin: 0 0 var(--space-l);
}
.reason-card {
  background: #fff;
  border-radius: 16px;
  padding: 20px 16px;
  border-left: 5px solid;
  box-shadow: 0 3px 12px rgba(0,0,0,0.07);
  transition: transform 0.22s;
}
.reason-card:hover { transform: translateX(5px); }
.reason-icon  { font-size: 2rem; display: block; margin-bottom: 10px; }
.reason-title { font-weight: 900; font-size: 1rem; margin-bottom: 7px; }
.reason-desc  { font-size: 0.82rem; line-height: 1.68; color: var(--text-mid); }

/* ── 角色分工卡 ── */
.role-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
  margin: 0 0 var(--space-l);
}
@media (max-width: 480px) { .role-grid { grid-template-columns: 1fr; } }

.role-card {
  border-radius: 18px;
  padding: 24px 18px;
  text-align: center;
}
.role-card.parent {
  background: linear-gradient(135deg, #EAF5E0, #D4EFC6);
  border: 2px solid #6DB33F;
}
.role-card.child {
  background: linear-gradient(135deg, #FFF0F0, #FFE0DF);
  border: 2px solid #D94040;
}
.role-icon  { font-size: 2.8rem; display: block; margin-bottom: 10px; animation: float2 4s ease-in-out infinite; }
.role-title { font-weight: 900; font-size: 1.05rem; margin-bottom: 12px; }
.role-tasks { list-style: none; padding: 0; margin: 0; text-align: left; }
.role-tasks li {
  font-size: 0.83rem;
  padding: 6px 0;
  border-bottom: 1px dashed rgba(0,0,0,0.1);
  display: flex; align-items: flex-start; gap: 6px; line-height: 1.5;
}
.role-tasks li:last-child { border: none; }
.role-tasks li::before { content: '✓'; color: var(--green-mid); font-weight: 900; flex-shrink: 0; }

/* ── 規則圖卡（不吵架秘訣） ── */
.rule-cards { display: flex; flex-direction: column; gap: 12px; margin: 0 0 var(--space-l); }
.rule-card {
  display: grid;
  grid-template-columns: 56px 1fr;
  gap: 14px;
  background: #fff;
  border-radius: 16px;
  padding: 16px;
  box-shadow: 0 2px 10px rgba(0,0,0,0.07);
  align-items: center;
  transition: transform 0.22s;
}
.rule-card:hover { transform: translateX(5px); }
.rule-icon-box {
  width: 52px; height: 52px;
  border-radius: 14px;
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  font-size: 1.6rem;
  flex-shrink: 0;
}
.rule-body h4 { font-size: 0.95rem; font-weight: 900; margin-bottom: 6px; color: var(--text-dark); }
.rule-body p  { font-size: 0.81rem; color: var(--text-mid); margin: 0; line-height: 1.58; }
.vs-pair {
  display: flex; gap: 8px; margin-top: 7px; flex-wrap: wrap;
}
.vs-bad  { background: #FFF0F0; border: 1px solid #F4AAAA; color: #B02020; border-radius: 8px; padding: 5px 10px; font-size: 0.78rem; }
.vs-good { background: #F0FAF0; border: 1px solid #90CFA0; color: #1A6A1A; border-radius: 8px; padding: 5px 10px; font-size: 0.78rem; }
.vs-arrow { font-size: 0.9rem; align-self: center; color: var(--text-muted); }

/* ── Oatchi 技能排行卡 ── */
.oatchi-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(145px, 1fr));
  gap: 12px;
  margin: 0 0 var(--space-l);
}
.oatchi-card {
  background: #fff;
  border-radius: 16px;
  padding: 18px 12px;
  text-align: center;
  box-shadow: 0 3px 12px rgba(0,0,0,0.08);
  border-top: 5px solid;
  transition: transform 0.22s;
}
.oatchi-card:hover { transform: translateY(-4px); }
.oatchi-rank { font-size: 0.7rem; font-weight: 800; letter-spacing: 0.08em; text-transform: uppercase; color: var(--text-muted); margin-bottom: 3px; }
.oatchi-num  { font-size: 2rem; font-weight: 900; display: block; line-height: 1; margin-bottom: 6px; }
.oatchi-emoji { font-size: 1.6rem; display: block; margin-bottom: 6px; }
.oatchi-skill { font-weight: 800; font-size: 0.88rem; margin-bottom: 4px; }
.oatchi-why   { font-size: 0.76rem; color: var(--text-mid); line-height: 1.5; }

/* ── Q&A 卡片 ── */
.qa-list { display: flex; flex-direction: column; gap: 14px; margin: 0 0 var(--space-l); }
.qa-card { background: #fff; border-radius: 16px; overflow: hidden; box-shadow: 0 2px 10px rgba(0,0,0,0.07); }
.qa-q {
  background: var(--green-dark);
  color: #fff;
  padding: 13px 16px;
  font-size: 0.88rem; font-weight: 700;
  display: flex; align-items: flex-start; gap: 8px;
}
.qa-q::before { content: 'Q'; font-size: 1rem; font-weight: 900; opacity: 0.7; flex-shrink: 0; }
.qa-a { padding: 14px 16px; font-size: 0.86rem; line-height: 1.75; color: var(--text-mid); }
.qa-a strong { color: var(--green-dark); }

/* ── 時間表圖卡 ── */
.time-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 12px;
  margin: 0 0 var(--space-l);
}
@media (max-width: 480px) { .time-grid { grid-template-columns: 1fr; } }

.time-card {
  background: #fff;
  border-radius: 16px;
  padding: 18px 16px;
  border-top: 5px solid;
  box-shadow: 0 2px 10px rgba(0,0,0,0.07);
}
.time-emoji    { font-size: 1.8rem; display: block; margin-bottom: 8px; }
.time-label    { font-size: 0.78rem; font-weight: 800; letter-spacing: 0.06em; text-transform: uppercase; color: var(--text-muted); margin-bottom: 4px; }
.time-duration { font-size: 1.5rem; font-weight: 900; color: var(--green-dark); line-height: 1; margin-bottom: 8px; }
.time-cond     { font-size: 0.8rem; color: var(--text-mid); line-height: 1.55; }

/* ── 獎勵兌換圖卡 ── */
.reward-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(145px, 1fr));
  gap: 12px;
  margin: 0 0 var(--space-l);
}
.reward-card {
  background: #fff;
  border-radius: 16px;
  padding: 18px 12px;
  text-align: center;
  border: 2px solid var(--card-border);
  transition: transform 0.22s, border-color 0.22s;
}
.reward-card:hover { transform: translateY(-5px); border-color: var(--green-mid); box-shadow: 0 8px 20px rgba(61,139,55,0.18); }
.reward-flowers { font-size: 1.3rem; display: block; margin-bottom: 6px; }
.reward-pts     { font-size: 1.6rem; font-weight: 900; color: var(--green-dark); display: block; line-height: 1; margin-bottom: 6px; }
.reward-pts-unit { font-size: 0.8rem; font-weight: 500; }
.reward-item    { font-size: 0.8rem; color: var(--text-mid); line-height: 1.5; margin-top: 4px; }

/* ── 積分表（全寬，無溢出） ── */
.score-table {
  width: 100%;
  border-collapse: separate;
  border-spacing: 0 6px;
  margin: var(--space-m) 0 var(--space-l);
  font-size: 0.88rem;
}
.score-table thead th {
  background: var(--green-dark);
  color: #fff;
  padding: 10px 14px;
  font-weight: 800;
  text-align: left;
}
.score-table thead th:first-child { border-radius: 12px 0 0 12px; }
.score-table thead th:last-child  { border-radius: 0 12px 12px 0; }
.score-table tbody tr td {
  background: #fff;
  padding: 10px 14px;
  border-top: 1px solid var(--card-border);
  border-bottom: 1px solid var(--card-border);
  vertical-align: middle;
}
.score-table tbody tr td:first-child { border-left: 1px solid var(--card-border); border-radius: 12px 0 0 12px; font-weight: 700; }
.score-table tbody tr td:last-child  { border-right: 1px solid var(--card-border); border-radius: 0 12px 12px 0; }
.score-badge {
  display: inline-block;
  background: var(--green-mid);
  color: #fff;
  padding: 2px 12px;
  border-radius: 99px;
  font-weight: 800; font-size: 0.84rem;
  white-space: nowrap;
}
.score-badge.bonus { background: var(--pikmin-yellow); color: var(--text-dark); }
.score-badge.big   { background: var(--pikmin-red); }

/* ── 三原則步驟卡 ── */
.principle-cards {
  display: flex; flex-direction: column; gap: 14px;
  margin: 0 0 var(--space-l);
}
.principle-card {
  display: grid;
  grid-template-columns: 64px 1fr;
  gap: 16px;
  background: #fff;
  border-radius: 18px;
  padding: 20px 18px;
  align-items: flex-start;
  box-shadow: 0 3px 14px rgba(0,0,0,0.08);
}
.principle-num {
  width: 52px; height: 52px;
  border-radius: 16px;
  display: flex; align-items: center; justify-content: center;
  font-size: 1.6rem; font-weight: 900; color: #fff;
  flex-shrink: 0;
}
.principle-body h4 { font-size: 1rem; font-weight: 900; margin-bottom: 7px; color: var(--text-dark); }
.principle-body p  { font-size: 0.84rem; color: var(--text-mid); line-height: 1.7; margin: 0; }

/* ── 頁面內的 tip/warn 框 ── */
.fun-tip-box {
  border-radius: 16px;
  padding: var(--space-l) var(--space-l);
  margin: var(--space-l) 0;
  font-size: 0.88rem;
  line-height: 1.75;
}
.fun-tip-box.green {
  background: var(--green-pale);
  border: 2px solid var(--green-light);
}
.fun-tip-box.yellow {
  background: #FFFCE0;
  border: 2px solid #D4A017;
}
.fun-tip-box.red {
  background: #FFF4F4;
  border: 2px solid #D94040;
}
.fun-tip-box-title {
  font-size: 1rem; font-weight: 900;
  margin-bottom: 10px;
  display: flex; align-items: center; gap: 6px;
}
.fun-tip-box p { margin-bottom: 8px; }
.fun-tip-box p:last-child { margin-bottom: 0; }
.fun-tip-box strong { color: var(--green-dark); }

/* ── hero 浮動元素 ── */
.hero-floats {
  position: absolute;
  inset: 0;
  z-index: 1;
  pointer-events: none;
  overflow: hidden;
}
.hero-float {
  position: absolute;
  font-size: 2rem;
  opacity: 0.35;
  animation: float 4s ease-in-out infinite;
}

/* ── 段落標頭橫幅 ── */
.section-banner {
  display: flex;
  align-items: center;
  gap: 16px;
  padding: 20px 24px;
  border-radius: 20px;
  margin-bottom: var(--space-xl);
}
.section-banner.discover { background: linear-gradient(135deg, #D8E8FF, #EEF5FF); border: 2px solid #2F69C2; }
.section-banner.family   { background: linear-gradient(135deg, #FFE0E0, #FFF3F3); border: 2px solid #D94040; }
.section-banner.tips     { background: linear-gradient(135deg, #FFF3C0, #FFFCE0); border: 2px solid #D4A017; }
.section-banner.schedule { background: linear-gradient(135deg, #E8D8FF, #F6F0FF); border: 2px solid #7B4FBF; }

.banner-icon { font-size: 3rem; animation: float 3s ease-in-out infinite; flex-shrink: 0; }
.banner-title {
  font-size: clamp(1.2rem, 3vw, 1.7rem);
  font-weight: 900;
  line-height: 1.3;
}
.banner-sub {
  font-size: 0.85rem;
  font-weight: 500;
  margin-top: 4px;
  opacity: 0.75;
}

/* ── intro 段落文字 ── */
.intro-text {
  font-size: 1rem;
  line-height: 1.9;
  margin-bottom: var(--space-l);
  background: #fff;
  border-radius: 14px;
  padding: 14px 18px;
  box-shadow: 0 2px 8px rgba(0,0,0,0.05);
}

/* ── 全寬表格修正（首頁） ── */
.page-content table {
  width: 100%;
  border-collapse: collapse;
  display: table;
  overflow-x: visible;
  font-size: 0.9rem;
  margin: var(--space-m) 0 var(--space-l);
}
.page-content th, .page-content td { word-break: break-word; min-width: 0; }

/* ── prefers-reduced-motion 無障礙支援 ── */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
  }
  .js-enabled .anim,
  .js-enabled .anim.visible {
    opacity: 1;
    transform: none;
    transition: none;
  }
}

/* ── 手機 sticky nav wrap 後 anchor 偏移修正 ── */
@media (max-width: 480px) {
  .anchor-target { scroll-margin-top: 160px; }
  .nav-tag { padding: 7px 12px; font-size: 0.8rem; }
}

/* ── score-table 手機保護 wrapper ── */
.table-scroll-wrap {
  width: 100%;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  border-radius: 12px;
  margin: var(--space-m) 0 var(--space-l);
}
.table-scroll-wrap .score-table { margin: 0; }
.score-table td, .score-table th {
  word-break: break-word;
  min-width: 60px;
}
@media (max-width: 480px) {
  .score-table { font-size: 0.78rem; }
  .score-table th, .score-table td { padding: 8px 8px; }
}
