/* ============================================================
   INNER.CSS — All inner/destination pages
   ============================================================ */

/* ——— HERO ——— */
.pg-hero { position:relative; height:420px; display:flex; align-items:flex-end; overflow:hidden; margin-top:var(--nav-h); }
.pg-hero__img { position:absolute; inset:0; background-size:cover; background-position:center; transition:transform 8s ease; }
.pg-hero:hover .pg-hero__img { transform:scale(1.04); }
.pg-hero__overlay { position:absolute; inset:0; background:linear-gradient(to bottom,rgba(0,0,0,.2) 0%,rgba(0,0,0,.65) 100%); }
.pg-hero__inner { position:relative; z-index:2; padding-bottom:40px; width:100%; }
.pg-hero__eyebrow { font-family:var(--body); font-size:10px; font-weight:500; letter-spacing:3px; text-transform:uppercase; color:rgba(255,255,255,.65); margin-bottom:10px; }
.pg-hero__title { font-family:var(--serif); font-size:clamp(32px,5vw,60px); font-weight:400; color:#fff; line-height:1.05; margin-bottom:12px; }
.pg-hero__sub { font-family:var(--body); font-size:15px; color:rgba(255,255,255,.75); line-height:1.65; max-width:600px; }

/* ——— BREADCRUMB ——— */
.pg-breadcrumb { background:var(--surface-1); border-bottom:1px solid var(--border); }
.pg-breadcrumb__inner { display:flex; align-items:center; gap:8px; padding:12px 24px; font-family:var(--body); font-size:12px; color:var(--text-muted); }
.pg-breadcrumb a { color:var(--green); text-decoration:none; transition:color var(--t-fast); }
.pg-breadcrumb a:hover { color:var(--green-lt); }
.pg-breadcrumb span[aria-current] { color:var(--text-secondary); }

/* ——— STATS BAR ——— */
.pg-stats-bar { background:#fff; border-bottom:1px solid var(--border); }
.pg-stats-bar__inner { display:flex; flex-wrap:wrap; gap:0; padding:0; }
.pg-stat { display:flex; align-items:center; gap:8px; padding:14px 20px; border-right:1px solid var(--border); flex-shrink:0; }
.pg-stat:last-child { border-right:none; }
.pg-stat__icon { font-size:14px; flex-shrink:0; }
.pg-stat__label { font-family:var(--body); font-size:10px; font-weight:600; letter-spacing:1px; text-transform:uppercase; color:var(--text-muted); white-space:nowrap; }
.pg-stat__val { font-family:var(--body); font-size:12px; color:var(--text-secondary); margin-left:4px; }
@media (max-width:900px) { .pg-stats-bar__inner { flex-wrap:wrap; } .pg-stat { flex:1 1 45%; border-bottom:1px solid var(--border); } }

/* ——— LAYOUT ——— */
.pg-main { padding:48px 0 80px; }
.pg-layout { display:grid; grid-template-columns:1fr 300px; gap:48px; align-items:start; }
.pg-content { min-width:0; }
@media (max-width:1024px) { .pg-layout { grid-template-columns:1fr; } .pg-sidebar { display:grid; grid-template-columns:repeat(2,1fr); gap:16px; } }
@media (max-width:640px) { .pg-sidebar { grid-template-columns:1fr; } }

/* ——— SECTION ——— */
.pg-section { margin-bottom:60px; padding-bottom:60px; border-bottom:1px solid var(--border); }
.pg-section:last-child { border-bottom:none; padding-bottom:0; }
.pg-h2 { font-family:var(--serif); font-size:clamp(24px,3vw,34px); font-weight:400; color:var(--text-primary); margin-bottom:18px; line-height:1.15; }
.pg-h2::after { content:''; display:block; width:40px; height:2px; background:var(--green); margin-top:10px; opacity:.5; }
.pg-h3 { font-family:var(--serif); font-size:20px; font-weight:400; color:var(--text-primary); margin:24px 0 10px; }
.pg-lead { font-size:16px; color:var(--text-secondary); line-height:1.8; margin-bottom:16px; }
.pg-content p { font-size:14px; color:var(--text-secondary); line-height:1.8; margin-bottom:14px; }
.pg-content p:last-child { margin-bottom:0; }
.pg-list { padding-left:0; margin:14px 0 18px; display:flex; flex-direction:column; gap:10px; }
.pg-list li { font-size:14px; color:var(--text-secondary); line-height:1.7; padding-left:18px; position:relative; }
.pg-list li::before { content:'→'; position:absolute; left:0; color:var(--green); font-size:12px; top:3px; }

/* ——— HIGHLIGHT BOX ——— */
.pg-highlight-box { display:flex; align-items:flex-start; gap:14px; background:var(--green-dim); border:1px solid rgba(45,106,79,.15); border-radius:6px; padding:18px 20px; margin:20px 0; }
.pg-highlight-box__icon { font-size:22px; flex-shrink:0; }
.pg-highlight-box strong { display:block; font-family:var(--body); font-size:13px; font-weight:600; color:var(--text-primary); margin-bottom:4px; }
.pg-highlight-box p { font-size:13px; color:var(--text-secondary); line-height:1.65; margin:0; }

/* ——— INFO BOX ——— */
.pg-info-box { background:var(--surface-1); border-left:3px solid var(--green); border-radius:0 4px 4px 0; padding:16px 18px; margin:20px 0; font-size:13px; color:var(--text-secondary); line-height:1.7; }
.pg-info-box strong { color:var(--text-primary); }

/* ——— PARKS GRID ——— */
.pg-parks-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:16px; margin:24px 0; }
.pg-park-card { display:flex; flex-direction:column; border:1px solid var(--border); border-radius:8px; overflow:hidden; text-decoration:none; background:var(--base); transition:box-shadow .25s ease,transform .25s ease; }
.pg-park-card:hover { box-shadow:0 6px 24px rgba(0,0,0,.1); transform:translateY(-2px); }
.pg-park-card__img { height:160px; background-size:cover; background-position:center; transition:transform .4s ease; }
.pg-park-card:hover .pg-park-card__img { transform:scale(1.05); }
.pg-park-card__body { padding:16px; flex:1; display:flex; flex-direction:column; }
.pg-park-card__circuit { font-family:var(--body); font-size:9px; font-weight:600; letter-spacing:2px; text-transform:uppercase; color:var(--green); margin-bottom:6px; }
.pg-park-card__name { font-family:var(--serif); font-size:18px; font-weight:700; color:var(--text-primary); margin-bottom:8px; line-height:1.2; }
.pg-park-card:hover .pg-park-card__name { color:var(--green); }
.pg-park-card__desc { font-size:13px; color:var(--text-muted); line-height:1.65; margin-bottom:12px; flex:1; }
.pg-park-card__meta { display:flex; justify-content:space-between; font-size:11px; color:var(--text-muted); margin-bottom:10px; border-top:1px solid var(--border); padding-top:10px; flex-wrap:wrap; gap:4px; }
.pg-park-card__link { font-family:var(--body); font-size:12px; font-weight:500; color:var(--green); margin-top:auto; transition:color .2s; }
.pg-park-card:hover .pg-park-card__link { color:var(--green-lt); }
@media (max-width:640px) { .pg-parks-grid { grid-template-columns:1fr; } }

/* ——— SEASON GRID ——— */
.pg-season-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:14px; margin:20px 0; }
.pg-season-card { background:var(--surface-1); border:1px solid var(--border); border-radius:6px; padding:22px; position:relative; }
.pg-season-card--best { border-color:var(--green); background:var(--green-dim); }
.pg-season-card__badge { position:absolute; top:-10px; left:16px; background:var(--green); color:#fff; font-family:var(--body); font-size:9px; font-weight:600; letter-spacing:1.5px; text-transform:uppercase; padding:4px 10px; border-radius:20px; }
.pg-season-card__title { font-family:var(--serif); font-size:18px; font-weight:700; color:var(--text-primary); margin-bottom:4px; }
.pg-season-card__months { font-family:var(--body); font-size:11px; font-weight:500; color:var(--green); letter-spacing:.5px; margin-bottom:10px; }
.pg-season-card__desc { font-size:13px; color:var(--text-secondary); line-height:1.7; margin-bottom:12px; }
.pg-season-list { display:flex; flex-direction:column; gap:6px; padding:0; }
.pg-season-list li { font-size:12px; color:var(--text-muted); padding-left:14px; position:relative; line-height:1.5; }
.pg-season-list li::before { content:'·'; position:absolute; left:3px; color:var(--green); font-weight:700; }
@media (max-width:640px) { .pg-season-grid { grid-template-columns:1fr; } }

/* ——— CIRCUIT LIST ——— */
.pg-circuit-list { display:flex; flex-direction:column; gap:0; margin-top:20px; }
.pg-circuit { padding:24px; border:1px solid var(--border); border-bottom:none; background:var(--base); transition:background .2s; }
.pg-circuit:first-child { border-radius:6px 6px 0 0; }
.pg-circuit:last-child { border-bottom:1px solid var(--border); border-radius:0 0 6px 6px; }
.pg-circuit:hover { background:var(--surface-1); }
.pg-circuit__header { display:flex; align-items:flex-start; gap:16px; margin-bottom:12px; }
.pg-circuit__num { font-family:var(--serif); font-size:28px; font-weight:400; color:rgba(45,106,79,.2); line-height:1; flex-shrink:0; width:40px; }
.pg-circuit__name { font-family:var(--serif); font-size:20px; font-weight:700; color:var(--text-primary); margin-bottom:3px; line-height:1.1; }
.pg-circuit__parks { font-family:var(--body); font-size:11px; color:var(--green); letter-spacing:.5px; }
.pg-circuit__desc { font-size:13px; color:var(--text-secondary); line-height:1.75; margin-bottom:14px; }
.pg-circuit__tags { display:flex; flex-wrap:wrap; gap:6px; }
.pg-circuit__tags span { font-family:var(--body); font-size:11px; color:var(--text-muted); background:var(--surface-2); padding:4px 10px; border-radius:20px; }

/* ——— WILDLIFE GRID ——— */
.pg-wildlife-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:0; margin:20px 0; border:1px solid var(--border); border-radius:6px; overflow:hidden; }
.pg-wildlife-item { display:flex; align-items:flex-start; gap:12px; padding:18px; border-bottom:1px solid var(--border); border-right:1px solid var(--border); background:var(--base); transition:background .2s; }
.pg-wildlife-item:hover { background:var(--surface-1); }
.pg-wildlife-item:nth-child(2n) { border-right:none; }
.pg-wildlife-item:nth-last-child(-n+2) { border-bottom:none; }
.pg-wildlife-icon { font-size:22px; flex-shrink:0; width:30px; text-align:center; }
.pg-wildlife-item strong { display:block; font-family:var(--body); font-size:13px; font-weight:600; color:var(--text-primary); margin-bottom:4px; }
.pg-wildlife-item p { font-size:12px; color:var(--text-muted); line-height:1.6; margin:0; }
@media (max-width:580px) { .pg-wildlife-grid { grid-template-columns:1fr; } .pg-wildlife-item:nth-child(2n) { border-right:none; } .pg-wildlife-item { border-right:none !important; } .pg-wildlife-item:last-child { border-bottom:none; } }

/* ——— COST TABLE ——— */
.pg-cost-table { border:1px solid var(--border); border-radius:6px; overflow:hidden; margin:20px 0; }
.pg-cost-row { display:grid; grid-template-columns:120px 1fr 140px; gap:12px; align-items:center; padding:14px 18px; border-bottom:1px solid var(--border); font-size:13px; }
.pg-cost-row:last-child { border-bottom:none; }
.pg-cost-row--header { background:var(--surface-2); font-family:var(--body); font-size:10px; font-weight:600; letter-spacing:1.5px; text-transform:uppercase; color:var(--text-muted); }
.pg-cost-row:not(.pg-cost-row--header):hover { background:var(--surface-1); }
.pg-cost-tier { font-family:var(--body); font-size:11px; font-weight:600; padding:4px 10px; border-radius:20px; text-align:center; }
.pg-cost-tier--budget { background:rgba(45,106,79,.08); color:var(--green); }
.pg-cost-tier--mid { background:rgba(45,106,79,.14); color:var(--green); }
.pg-cost-tier--lux { background:rgba(45,106,79,.22); color:var(--green); }
.pg-cost-tier--ultra { background:var(--green); color:#fff; }
.pg-cost-price { font-family:var(--serif); font-size:15px; font-weight:700; color:var(--text-primary); text-align:right; }
@media (max-width:580px) { .pg-cost-row { grid-template-columns:1fr 1fr; } .pg-cost-row > span:nth-child(2) { grid-column:1/-1; color:var(--text-muted); font-size:12px; } }

/* ——— PRACTICAL GRID ——— */
.pg-practical-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:16px; margin-top:20px; }
.pg-practical-item { background:var(--surface-1); border:1px solid var(--border); border-radius:6px; padding:20px; }
.pg-practical-item__title { font-family:var(--body); font-size:14px; font-weight:600; color:var(--text-primary); margin-bottom:10px; }
.pg-practical-item p { font-size:13px; color:var(--text-secondary); line-height:1.75; margin:0; }
.pg-practical-item a { color:var(--green); text-decoration:underline; }
@media (max-width:640px) { .pg-practical-grid { grid-template-columns:1fr; } }

/* ——— FAQ ——— */
.pg-faq { display:flex; flex-direction:column; margin-top:20px; }
.pg-faq-item { border-bottom:1px solid var(--border); }
.pg-faq-item:first-child { border-top:1px solid var(--border); }
.pg-faq-q { list-style:none; display:flex; align-items:center; justify-content:space-between; padding:16px 0; font-family:var(--body); font-size:14px; font-weight:500; color:var(--text-primary); cursor:pointer; gap:12px; user-select:none; transition:color var(--t-fast); }
.pg-faq-q:hover { color:var(--green); }
.pg-faq-q::-webkit-details-marker { display:none; }
.pg-faq-q::after { content:'+'; font-size:20px; font-weight:300; color:var(--text-muted); flex-shrink:0; transition:transform .2s ease; line-height:1; }
.pg-faq-item[open] .pg-faq-q::after { transform:rotate(45deg); }
.pg-faq-a { padding:0 0 16px; }
.pg-faq-a p { font-size:14px; color:var(--text-secondary); line-height:1.8; }
.pg-faq-a a { color:var(--green); text-decoration:underline; }

/* ——— CTA BOX ——— */
.pg-cta-section { background:var(--surface-1); border-radius:8px; padding:36px !important; border:1px solid var(--border); margin-top:0; }
.pg-cta-section.pg-section { border-bottom:none; }
.pg-cta-box { display:flex; align-items:center; justify-content:space-between; gap:32px; flex-wrap:wrap; }
.pg-cta-box__title { font-family:var(--serif); font-size:24px; font-weight:700; color:var(--text-primary); margin-bottom:8px; }
.pg-cta-box p { font-size:14px; color:var(--text-secondary); line-height:1.7; max-width:480px; margin:0; }
.pg-cta-box__actions { display:flex; gap:10px; flex-direction:column; flex-shrink:0; min-width:200px; }

/* ——— BUTTONS ——— */
.pg-btn { display:inline-flex; align-items:center; justify-content:center; gap:8px; padding:12px 22px; border-radius:3px; font-family:var(--body); font-size:13px; font-weight:500; text-decoration:none; transition:all .2s ease; cursor:pointer; border:none; white-space:nowrap; }
.pg-btn--primary { background:var(--green); color:#fff; }
.pg-btn--primary:hover { background:var(--green-lt); }
.pg-btn--wa { background:rgba(37,211,102,.08); border:1px solid rgba(37,211,102,.25); color:#1a7a3a; }
.pg-btn--wa:hover { background:rgba(37,211,102,.15); }
.pg-btn--full { width:100%; }

/* ——— SIDEBAR ——— */
.pg-sidebar { display:flex; flex-direction:column; gap:16px; position:sticky; top:calc(var(--nav-h) + 24px); }
.pg-sidebar-card { background:var(--base); border:1px solid var(--border); border-radius:6px; padding:20px; }
.pg-sidebar-card__title { font-family:var(--body); font-size:10px; font-weight:600; letter-spacing:2px; text-transform:uppercase; color:var(--text-muted); margin-bottom:14px; padding-bottom:10px; border-bottom:1px solid var(--border); }
.pg-sidebar-card--cta { background:var(--green-dim); border-color:rgba(45,106,79,.2); display:flex; flex-direction:column; gap:8px; }
.pg-sidebar-cta__title { font-family:var(--serif); font-size:16px; font-weight:700; color:var(--text-primary); }
.pg-sidebar-cta__sub { font-size:12px; color:var(--text-muted); margin-bottom:4px; }

/* TOC */
.pg-toc { display:flex; flex-direction:column; gap:2px; }
.pg-toc__link { font-family:var(--body); font-size:13px; color:var(--text-secondary); text-decoration:none; padding:6px 8px; border-radius:3px; transition:color var(--t-fast),background var(--t-fast); border-left:2px solid transparent; }
.pg-toc__link:hover { color:var(--green); background:var(--green-dim); }
.pg-toc__link--active { color:var(--green); border-left-color:var(--green); background:var(--green-dim); font-weight:500; }

/* Quick Facts */
.pg-quick-facts { display:flex; flex-direction:column; gap:0; }
.pg-quick-facts li { display:flex; justify-content:space-between; align-items:center; padding:8px 0; border-bottom:1px solid var(--border); font-size:12px; gap:8px; }
.pg-quick-facts li:last-child { border-bottom:none; }
.pg-quick-facts li span:first-child { color:var(--text-muted); flex-shrink:0; }
.pg-quick-facts li span:last-child { color:var(--text-primary); font-weight:500; text-align:right; }

/* Sidebar links */
.pg-sidebar-links { display:flex; flex-direction:column; gap:4px; }
.pg-sidebar-links a { font-size:13px; color:var(--text-secondary); text-decoration:none; padding:7px 8px; border-radius:3px; transition:color var(--t-fast),background var(--t-fast); display:block; }
.pg-sidebar-links a:hover { color:var(--green); background:var(--green-dim); }

/* ——— RESPONSIVE ——— */
@media (max-width:1024px) {
  .pg-sidebar { position:static; display:grid; grid-template-columns:repeat(2,1fr); gap:14px; }
  .pg-sidebar-card:first-child { grid-column:1/-1; }
}
@media (max-width:640px) {
  .pg-hero { height:320px; }
  .pg-hero__title { font-size:28px; }
  .pg-sidebar { grid-template-columns:1fr; }
  .pg-sidebar-card:first-child { grid-column:auto; }
  .pg-cta-box { flex-direction:column; align-items:flex-start; }
  .pg-cta-box__actions { width:100%; }
}


/* ============================================================
   SERENGETI / PARK-SPECIFIC ADDITIONS
   ============================================================ */

/* ——— ZONES ——— */
.pg-zone-list { display:flex; flex-direction:column; gap:0; margin:24px 0; }
.pg-zone { padding:24px; border:1px solid var(--border); border-bottom:none; background:var(--base); transition:background .2s; }
.pg-zone:first-child { border-radius:6px 6px 0 0; }
.pg-zone:last-child { border-bottom:1px solid var(--border); border-radius:0 0 6px 6px; }
.pg-zone:hover { background:var(--surface-1); }
.pg-zone__header { display:flex; align-items:center; gap:14px; margin-bottom:12px; flex-wrap:wrap; }
.pg-zone__dot { width:12px; height:12px; border-radius:50%; flex-shrink:0; }
.pg-zone__dot--north   { background:#2D6A4F; }
.pg-zone__dot--central { background:#40916C; }
.pg-zone__dot--south   { background:#74C69D; }
.pg-zone__dot--west    { background:#B7E4C7; border:1px solid #74C69D; }
.pg-zone__name { font-family:var(--serif); font-size:19px; font-weight:700; color:var(--text-primary); margin-bottom:2px; line-height:1.1; }
.pg-zone__sub { font-size:11px; color:var(--text-muted); }
.pg-zone__best { margin-left:auto; font-family:var(--body); font-size:10px; font-weight:600; letter-spacing:1px; text-transform:uppercase; color:var(--green); background:var(--green-dim); padding:4px 10px; border-radius:20px; white-space:nowrap; flex-shrink:0; }
.pg-zone__desc { font-size:13px; color:var(--text-secondary); line-height:1.75; margin-bottom:12px; }
.pg-zone__tags { display:flex; flex-wrap:wrap; gap:6px; }
.pg-zone__tags span { font-size:11px; color:var(--text-muted); background:var(--surface-2); padding:4px 10px; border-radius:20px; }

/* ——— MIGRATION TABLE ——— */
.pg-migration-table { border:1px solid var(--border); border-radius:6px; overflow:hidden; margin:20px 0; }
.pg-mig-row { display:grid; grid-template-columns:90px 1fr 1.4fr 110px; gap:12px; align-items:center; padding:12px 16px; border-bottom:1px solid var(--border); font-size:13px; }
.pg-mig-row:last-child { border-bottom:none; }
.pg-mig-row--header { background:var(--surface-2); font-family:var(--body); font-size:10px; font-weight:600; letter-spacing:1.5px; text-transform:uppercase; color:var(--text-muted); }
.pg-mig-row--peak { background:rgba(45,106,79,.04); }
.pg-mig-row--rain { background:rgba(0,0,0,.015); }
.pg-mig-row:not(.pg-mig-row--header):hover { background:var(--surface-1); }
.pg-mig-month { font-family:var(--body); font-size:12px; font-weight:600; color:var(--text-primary); }
.pg-mig-rating { font-family:var(--body); font-size:10px; font-weight:600; letter-spacing:.5px; padding:3px 9px; border-radius:20px; text-align:center; white-space:nowrap; }
.pg-mig-rating--excellent { background:rgba(45,106,79,.12); color:var(--green); }
.pg-mig-rating--good { background:rgba(45,106,79,.07); color:var(--green-lt); }
.pg-mig-rating--fair { background:var(--surface-2); color:var(--text-muted); }
.pg-mig-rating--low { background:rgba(0,0,0,.04); color:var(--text-muted); }
@media (max-width:700px) { .pg-mig-row { grid-template-columns:70px 1fr; row-gap:4px; } .pg-mig-row > span:nth-child(3) { grid-column:1/-1; color:var(--text-muted); font-size:12px; } .pg-mig-rating { width:fit-content; } }

/* ——— ACCOMMODATION CARDS ——— */
.pg-accom-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:14px; margin:20px 0; }
.pg-accom-card { background:var(--surface-1); border:1px solid var(--border); border-radius:6px; padding:22px; display:flex; flex-direction:column; gap:10px; }
.pg-accom-card__tier { font-family:var(--body); font-size:9px; font-weight:700; letter-spacing:2px; text-transform:uppercase; padding:4px 10px; border-radius:20px; width:fit-content; }
.pg-accom-card__tier--budget { background:rgba(45,106,79,.08); color:var(--green); }
.pg-accom-card__tier--mid    { background:rgba(45,106,79,.14); color:var(--green); }
.pg-accom-card__tier--lux    { background:rgba(45,106,79,.22); color:var(--green); }
.pg-accom-card__tier--ultra  { background:var(--green); color:#fff; }
.pg-accom-card__title { font-family:var(--serif); font-size:17px; font-weight:700; color:var(--text-primary); line-height:1.2; }
.pg-accom-card__price { font-family:var(--body); font-size:12px; font-weight:600; color:var(--green); }
.pg-accom-card__desc { font-size:13px; color:var(--text-secondary); line-height:1.7; }
.pg-accom-list { display:flex; flex-direction:column; gap:5px; border-top:1px solid var(--border); padding-top:10px; }
.pg-accom-list li { font-size:12px; color:var(--text-muted); padding-left:14px; position:relative; line-height:1.5; }
.pg-accom-list li::before { content:'·'; position:absolute; left:3px; color:var(--green); font-weight:700; }
@media (max-width:640px) { .pg-accom-grid { grid-template-columns:1fr; } }


/* ——— BEYOND THE CRATER CARDS ——— */
.pg-beyond-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:14px; margin:20px 0; }
.pg-beyond-card { background:var(--surface-1); border:1px solid var(--border); border-radius:6px; padding:22px; transition:background .2s; }
.pg-beyond-card:hover { background:var(--surface-2); }
.pg-beyond-card__icon { font-size:26px; margin-bottom:10px; display:block; }
.pg-beyond-card__title { font-family:var(--serif); font-size:17px; font-weight:700; color:var(--text-primary); margin-bottom:8px; line-height:1.2; }
.pg-beyond-card p { font-size:13px; color:var(--text-secondary); line-height:1.75; margin:0; }
.pg-beyond-card p em { color:var(--text-primary); font-style:italic; }
@media (max-width:640px) { .pg-beyond-grid { grid-template-columns:1fr; } }


/* ——— ACTIVITY CARDS (walking safaris, night drives etc) ——— */
.pg-activity-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:14px; margin:20px 0; }
.pg-activity-card { background:var(--surface-1); border:1px solid var(--border); border-radius:6px; padding:22px; transition:background .2s; }
.pg-activity-card:hover { background:var(--surface-2); }
.pg-activity-card__icon { font-size:28px; margin-bottom:10px; display:block; }
.pg-activity-card__title { font-family:var(--serif); font-size:18px; font-weight:700; color:var(--text-primary); margin-bottom:10px; }
.pg-activity-card__desc { font-size:13px; color:var(--text-secondary); line-height:1.75; margin-bottom:14px; }
.pg-activity-card__info { display:flex; flex-wrap:wrap; gap:8px; border-top:1px solid var(--border); padding-top:12px; }
.pg-activity-card__info span { font-family:var(--body); font-size:11px; color:var(--text-muted); background:var(--surface-2); padding:4px 10px; border-radius:20px; }
@media (max-width:640px) { .pg-activity-grid { grid-template-columns:1fr; } }


/* ============================================================
   KILIMANJARO — ROUTE CARDS, GEAR LIST, AMS, FITNESS, OPERATORS
   ============================================================ */

/* ——— ROUTE CARDS ——— */
.pg-route-grid { display:flex; flex-direction:column; gap:0; margin:24px 0; }
.pg-route-card { padding:24px; border:1px solid var(--border); border-bottom:none; background:var(--base); transition:background .2s; position:relative; }
.pg-route-card:first-child { border-radius:6px 6px 0 0; }
.pg-route-card:last-child { border-bottom:1px solid var(--border); border-radius:0 0 6px 6px; }
.pg-route-card:hover { background:var(--surface-1); }
.pg-route-card--recommended { background:var(--green-dim); border-color:rgba(45,106,79,.25); }
.pg-route-card--recommended:hover { background:rgba(45,106,79,.07); }
.pg-route-card__badge { position:absolute; top:-10px; left:20px; background:var(--green); color:#fff; font-family:var(--body); font-size:9px; font-weight:700; letter-spacing:1.5px; text-transform:uppercase; padding:4px 12px; border-radius:20px; }
.pg-route-card__header { display:flex; align-items:flex-start; justify-content:space-between; gap:16px; margin-bottom:10px; flex-wrap:wrap; }
.pg-route-card__name { font-family:var(--serif); font-size:20px; font-weight:700; color:var(--text-primary); line-height:1.1; }
.pg-route-card__ratings { display:flex; gap:8px; flex-wrap:wrap; flex-shrink:0; }
.pg-route-rating { font-family:var(--body); font-size:10px; font-weight:600; padding:4px 10px; border-radius:20px; white-space:nowrap; }
.pg-route-rating--success { background:rgba(45,106,79,.12); color:var(--green); }
.pg-route-rating--scenic  { background:var(--surface-2); color:var(--text-secondary); }
.pg-route-rating--caution { background:rgba(200,80,0,.08); color:#b85c00; }
.pg-route-rating--fair    { background:var(--surface-2); color:var(--text-muted); }
.pg-route-card__meta-row { display:flex; flex-wrap:wrap; gap:8px; margin-bottom:12px; }
.pg-route-card__meta-row span { font-family:var(--body); font-size:11px; color:var(--text-muted); background:var(--surface-2); padding:4px 10px; border-radius:20px; }
.pg-route-card__desc { font-size:13px; color:var(--text-secondary); line-height:1.75; margin-bottom:12px; }
.pg-route-card__camps { font-size:12px; color:var(--text-muted); line-height:1.6; border-top:1px solid var(--border); padding-top:10px; }
.pg-route-card__camps strong { color:var(--text-secondary); }

/* ——— ROUTE COMPARISON TABLE ——— */
.pg-route-compare-table { border:1px solid var(--border); border-radius:6px; overflow:hidden; margin:20px 0; }
.pg-rct-row { display:grid; grid-template-columns:140px 60px 90px 90px 1fr; gap:12px; align-items:center; padding:11px 16px; border-bottom:1px solid var(--border); font-size:13px; }
.pg-rct-row:last-child { border-bottom:none; }
.pg-rct-row--header { background:var(--surface-2); font-family:var(--body); font-size:10px; font-weight:600; letter-spacing:1.5px; text-transform:uppercase; color:var(--text-muted); }
.pg-rct-row--highlight { background:rgba(45,106,79,.05); }
.pg-rct-row:not(.pg-rct-row--header):hover { background:var(--surface-1); }
.pg-rct-good { color:var(--green); font-weight:600; font-size:12px; }
.pg-rct-mid  { color:#b8860b; font-weight:600; font-size:12px; }
.pg-rct-low  { color:#b84040; font-weight:600; font-size:12px; }
@media (max-width:700px) { .pg-rct-row { grid-template-columns:1fr 1fr; row-gap:4px; } .pg-rct-row > span:nth-child(5) { grid-column:1/-1; color:var(--text-muted); } }

/* ——— FITNESS GRID ——— */
.pg-fitness-grid { display:grid; grid-template-columns:1fr 1fr; gap:14px; margin:20px 0; }
.pg-fitness-card { border-radius:6px; padding:22px; border:1px solid var(--border); }
.pg-fitness-card--green { background:rgba(45,106,79,.06); border-color:rgba(45,106,79,.2); }
.pg-fitness-card--amber { background:rgba(200,120,0,.05); border-color:rgba(200,120,0,.2); }
.pg-fitness-card h4 { font-family:var(--body); font-size:14px; font-weight:600; color:var(--text-primary); margin-bottom:12px; }
.pg-fitness-card ul { display:flex; flex-direction:column; gap:7px; padding:0; }
.pg-fitness-card li { font-size:13px; color:var(--text-secondary); padding-left:16px; position:relative; line-height:1.5; }
.pg-fitness-card li::before { content:'→'; position:absolute; left:0; color:var(--green); font-size:11px; top:2px; }
.pg-fitness-card--amber li::before { color:#b85c00; }
@media (max-width:580px) { .pg-fitness-grid { grid-template-columns:1fr; } }

/* ——— AMS GRID ——— */
.pg-ams-grid { display:grid; grid-template-columns:1fr 1fr; gap:14px; margin:16px 0 20px; }
.pg-ams-card { border-radius:6px; padding:22px; border:1px solid var(--border); }
.pg-ams-card--mild     { background:rgba(45,106,79,.05); border-color:rgba(45,106,79,.2); }
.pg-ams-card--moderate { background:rgba(180,40,40,.05); border-color:rgba(180,40,40,.2); }
.pg-ams-card h4 { font-family:var(--body); font-size:14px; font-weight:600; color:var(--text-primary); margin-bottom:10px; }
.pg-ams-card p { font-size:13px; color:var(--text-secondary); line-height:1.65; margin-bottom:10px; }
.pg-ams-card ul { display:flex; flex-direction:column; gap:5px; margin-bottom:12px; }
.pg-ams-card li { font-size:12px; color:var(--text-secondary); padding-left:14px; position:relative; line-height:1.5; }
.pg-ams-card li::before { content:'·'; position:absolute; left:3px; color:var(--text-muted); font-weight:700; }
.pg-ams-action { font-size:12px; font-weight:600; color:var(--text-primary); background:rgba(0,0,0,.04); border-radius:3px; padding:8px 10px; margin:0 !important; }
@media (max-width:580px) { .pg-ams-grid { grid-template-columns:1fr; } }

/* ——— GEAR LIST ——— */
.pg-gear-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:14px; margin:20px 0; }
.pg-gear-category { background:var(--surface-1); border:1px solid var(--border); border-radius:6px; padding:20px; }
.pg-gear-category__title { font-family:var(--body); font-size:14px; font-weight:600; color:var(--text-primary); margin-bottom:12px; }
.pg-gear-list { display:flex; flex-direction:column; gap:7px; }
.pg-gear-list li { font-size:13px; color:var(--text-secondary); line-height:1.5; display:flex; align-items:baseline; gap:7px; }
.pg-gear-essential   { font-family:var(--body); font-size:9px; font-weight:700; letter-spacing:1px; text-transform:uppercase; background:var(--green); color:#fff; padding:2px 6px; border-radius:2px; flex-shrink:0; }
.pg-gear-recommended { font-family:var(--body); font-size:9px; font-weight:600; letter-spacing:1px; text-transform:uppercase; background:var(--surface-3); color:var(--text-muted); padding:2px 6px; border-radius:2px; flex-shrink:0; }
@media (max-width:640px) { .pg-gear-grid { grid-template-columns:1fr; } }

/* ——— OPERATOR CARDS ——— */
.pg-operator-grid { display:grid; grid-template-columns:1fr 1fr; gap:14px; margin:20px 0; }
.pg-operator-card { border-radius:6px; padding:22px; border:1px solid var(--border); }
.pg-operator-card--good { background:rgba(45,106,79,.05); border-color:rgba(45,106,79,.2); }
.pg-operator-card--bad  { background:rgba(180,40,40,.04); border-color:rgba(180,40,40,.15); }
.pg-operator-card__title { font-family:var(--body); font-size:14px; font-weight:600; color:var(--text-primary); margin-bottom:12px; }
@media (max-width:580px) { .pg-operator-grid { grid-template-columns:1fr; } }
