/* ═══════════════════════════════════════════════════════
   ASIEN TRIP 2026 — Lukas · Travel Blog Stylesheet
   ═══════════════════════════════════════════════════════ */

:root {
  --sand:   #E8DCC8;
  --deep:   #0D1117;
  --jungle: #1A3A2A;
  --lime:   #A8C96E;
  --amber:  #D4870A;
  --rust:   #B85C38;
  --water:  #3B7A8C;
  --mist:   #C9D8DC;
  --cream:  #F5EFE0;
  --text:   #1A1612;
  --visited:#7AAFC4;
  --now:    #F5D76E;
}

*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior: smooth; }
body {
  background: var(--deep);
  color: var(--sand);
  font-family: 'Outfit', sans-serif;
  font-weight: 300;
  overflow-x: hidden;
}

/* ── NOISE OVERLAY ──────────────────────────── */
.noise {
  position: fixed; inset: 0;
  opacity: 0.03;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)'/%3E%3C/svg%3E");
  pointer-events: none; z-index: 9999;
}

/* ── HERO ───────────────────────────────────── */
.hero {
  min-height: 100vh;
  display: grid;
  grid-template-rows: 1fr auto;
  position: relative; overflow: hidden;
  padding: 0 5vw;
  background: var(--deep);
}
.hero::before {
  content: '';
  position: absolute; inset: 0;
  background:
    radial-gradient(ellipse 60% 50% at 80% 30%, rgba(59,122,140,0.18) 0%, transparent 70%),
    radial-gradient(ellipse 40% 60% at 10% 80%, rgba(168,201,110,0.12) 0%, transparent 70%),
    radial-gradient(ellipse 30% 40% at 50% 10%, rgba(212,135,10,0.08) 0%, transparent 60%);
  pointer-events: none;
}
.hero-content {
  display: flex; flex-direction: column;
  justify-content: center;
  padding-top: 15vh; max-width: 900px;
}
.tag {
  font-family: 'DM Mono', monospace;
  font-size: 0.7rem; letter-spacing: 0.2em; text-transform: uppercase;
  color: var(--lime); margin-bottom: 2rem;
  opacity: 0; animation: fadeUp 0.8s ease forwards 0.2s;
}
.hero-title {
  font-family: 'Playfair Display', serif;
  font-size: clamp(3.5rem, 9vw, 8rem); font-weight: 900;
  line-height: 0.95; letter-spacing: -0.02em; margin-bottom: 2rem;
  opacity: 0; animation: fadeUp 0.8s ease forwards 0.4s;
}
.hero-title em { font-style: italic; color: var(--amber); }
.hero-sub {
  font-size: 1.1rem; font-weight: 300; color: rgba(232,220,200,0.6);
  max-width: 480px; line-height: 1.7;
  opacity: 0; animation: fadeUp 0.8s ease forwards 0.6s;
}
.hero-stats {
  display: flex; gap: 3rem; padding: 3rem 0 5vh;
  opacity: 0; animation: fadeUp 0.8s ease forwards 0.8s;
}
.stat { display: flex; flex-direction: column; gap: 0.3rem; }
.stat-num {
  font-family: 'Playfair Display', serif; font-size: 2.5rem;
  font-weight: 700; color: var(--lime); line-height: 1;
}
.stat-label {
  font-family: 'DM Mono', monospace; font-size: 0.65rem;
  letter-spacing: 0.15em; text-transform: uppercase;
  color: rgba(232,220,200,0.45);
}
.scroll-hint {
  padding-bottom: 3rem;
  display: flex; align-items: center; gap: 1rem;
  opacity: 0; animation: fadeUp 0.8s ease forwards 1.1s;
  color: rgba(232,220,200,0.3); font-family: 'DM Mono', monospace;
  font-size: 0.65rem; letter-spacing: 0.15em; text-transform: uppercase;
}
.scroll-line { width: 40px; height: 1px; background: currentColor; }

/* ── STATUS BANNER (date-driven) ─────────────── */
#status-banner {
  display: none;
  padding: 0.9rem 5vw;
  background: rgba(245,215,110,0.08);
  border-bottom: 1px solid rgba(245,215,110,0.2);
  font-family: 'DM Mono', monospace;
  font-size: 0.68rem; letter-spacing: 0.12em;
  text-transform: uppercase; color: var(--now);
  gap: 1.5rem; align-items: center;
  flex-wrap: wrap;
}
#status-banner.show { display: flex; }
.status-dot {
  width: 8px; height: 8px; border-radius: 50%;
  background: var(--now);
  animation: pulse-ring 2s ease infinite;
  flex-shrink: 0;
}
#countdown-strip {
  margin-left: auto;
  display: flex; gap: 1.5rem;
}
.cd-unit { text-align: center; }
.cd-num {
  font-family: 'Playfair Display', serif;
  font-size: 1.4rem; font-weight: 700; color: var(--lime);
  display: block; line-height: 1;
}
.cd-label { font-size: 0.55rem; opacity: 0.5; }

/* ── ROUTE BAR ──────────────────────────────── */
.route-bar {
  background: rgba(168,201,110,0.08);
  border-top: 1px solid rgba(168,201,110,0.15);
  border-bottom: 1px solid rgba(168,201,110,0.15);
  padding: 1.5rem 5vw;
  display: flex; align-items: center;
  overflow-x: auto; scrollbar-width: none;
}
.route-bar::-webkit-scrollbar { display: none; }
.route-stop { display: flex; align-items: center; white-space: nowrap; }
.route-city {
  font-family: 'DM Mono', monospace; font-size: 0.75rem;
  letter-spacing: 0.1em; text-transform: uppercase;
  padding: 0.4rem 1rem; border-radius: 2px; transition: all 0.2s;
}
.route-city.active  { color: var(--deep); background: var(--lime); }
.route-city.done    { color: rgba(232,220,200,0.4); }
.route-city.current { color: var(--amber); }
.route-city.here    {
  color: var(--deep); background: var(--now);
  animation: pulse-subtle 2s ease infinite;
}
.route-arrow { color: rgba(232,220,200,0.2); font-size: 0.8rem; padding: 0 0.5rem; }

/* ── GENERAL SECTION ────────────────────────── */
.section { padding: 8rem 5vw; position: relative; }
.section-label {
  font-family: 'DM Mono', monospace; font-size: 0.65rem;
  letter-spacing: 0.25em; text-transform: uppercase;
  color: var(--lime); margin-bottom: 1rem;
}
.section-title {
  font-family: 'Playfair Display', serif;
  font-size: clamp(2rem, 5vw, 3.5rem); font-weight: 700;
  line-height: 1.1; margin-bottom: 4rem;
}
.divider {
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(168,201,110,0.2), transparent);
  margin: 0 5vw;
}

/* ── BLOG / UPDATES ─────────────────────────── */
.blog-section { padding: 8rem 5vw; }
.blog-grid { display: grid; gap: 1.5rem; margin-top: 1rem; }
.blog-entry {
  background: rgba(255,255,255,0.025);
  border: 1px solid rgba(255,255,255,0.06);
  border-left: 3px solid var(--lime);
  border-radius: 0 4px 4px 0;
  padding: 1.8rem 2.2rem;
  opacity: 0; transform: translateX(-16px);
  transition: opacity 0.5s ease, transform 0.5s ease, background 0.3s;
  cursor: pointer;
}
.blog-entry:hover { background: rgba(255,255,255,0.045); }
.blog-entry.visible { opacity:1; transform: translateX(0); }
.blog-entry.pinned  { border-left-color: var(--amber); }
.blog-entry.adventure-entry { border-left-color: var(--amber); }

.blog-meta {
  display: flex; align-items: center; gap: 1rem;
  margin-bottom: 0.8rem; flex-wrap: wrap;
}
.blog-date {
  font-family: 'DM Mono', monospace; font-size: 0.6rem;
  letter-spacing: 0.14em; text-transform: uppercase;
  color: rgba(232,220,200,0.35);
}
.blog-tag {
  font-family: 'DM Mono', monospace; font-size: 0.55rem;
  letter-spacing: 0.1em; text-transform: uppercase;
  padding: 0.2rem 0.6rem; border-radius: 2px;
}
.blog-tag.tag-adventure { background: rgba(212,135,10,0.15); color: var(--amber); }
.blog-tag.tag-travel    { background: rgba(59,122,140,0.15);  color: var(--water); }
.blog-tag.tag-life      { background: rgba(168,201,110,0.12); color: var(--lime); }
.blog-tag.tag-food      { background: rgba(184,92,56,0.15);   color: var(--rust); }

.blog-title {
  font-family: 'Playfair Display', serif;
  font-size: 1.3rem; font-weight: 700; line-height: 1.2;
  margin-bottom: 0.7rem;
}
.blog-preview {
  font-size: 0.85rem; line-height: 1.65;
  color: rgba(232,220,200,0.58);
}
.blog-expand {
  max-height: 0; overflow: hidden;
  transition: max-height 0.5s ease;
}
.blog-expand.open { max-height: 800px; }
.blog-full {
  margin-top: 1rem; padding-top: 1rem;
  border-top: 1px solid rgba(255,255,255,0.06);
  font-size: 0.88rem; line-height: 1.8;
  color: rgba(232,220,200,0.7);
}
.blog-full p { margin-bottom: 0.8rem; }
.blog-read-more {
  margin-top: 0.8rem;
  font-family: 'DM Mono', monospace; font-size: 0.6rem;
  letter-spacing: 0.15em; text-transform: uppercase;
  color: var(--lime); display: inline-flex;
  align-items: center; gap: 0.4rem; cursor: pointer;
}
.blog-read-more .arrow { transition: transform 0.3s; }
.blog-read-more.open .arrow { transform: rotate(90deg); }

/* ── GALLERY ────────────────────────────────── */
.gallery-section { padding: 8rem 5vw; }
.gallery-toolbar {
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: 2rem; flex-wrap: wrap; gap: 1rem;
}
.gallery-filters {
  display: flex; gap: 0.5rem; flex-wrap: wrap;
}
.gf-btn {
  font-family: 'DM Mono', monospace; font-size: 0.6rem;
  letter-spacing: 0.12em; text-transform: uppercase;
  padding: 0.4rem 0.9rem; border-radius: 2px; border: none;
  cursor: pointer; transition: all 0.2s;
  background: rgba(255,255,255,0.06); color: rgba(232,220,200,0.5);
}
.gf-btn:hover  { background: rgba(255,255,255,0.1); color: var(--sand); }
.gf-btn.active { background: var(--lime); color: var(--deep); }

.upload-btn {
  display: flex; align-items: center; gap: 0.5rem;
  font-family: 'DM Mono', monospace; font-size: 0.62rem;
  letter-spacing: 0.12em; text-transform: uppercase;
  padding: 0.6rem 1.2rem; border-radius: 3px; border: none;
  background: rgba(168,201,110,0.12); color: var(--lime);
  border: 1px solid rgba(168,201,110,0.25); cursor: pointer;
  transition: all 0.2s;
}
.upload-btn:hover { background: rgba(168,201,110,0.22); }
.upload-btn svg { width: 14px; height: 14px; }

.gallery-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 6px;
}
.gallery-item {
  position: relative; overflow: hidden; border-radius: 3px;
  cursor: pointer; aspect-ratio: 4/3;
  background: rgba(255,255,255,0.04);
  opacity: 0; transform: scale(0.97);
  transition: opacity 0.5s ease, transform 0.5s ease;
}
.gallery-item.visible { opacity: 1; transform: scale(1); }
.gallery-item:hover .gallery-overlay { opacity: 1; }
.gallery-item.hidden-item { display: none; }

.gallery-img {
  width: 100%; height: 100%;
  object-fit: cover; display: block;
  transition: transform 0.4s ease;
}
.gallery-item:hover .gallery-img { transform: scale(1.04); }
.gallery-placeholder {
  width: 100%; height: 100%;
  display: flex; flex-direction: column;
  align-items: center; justify-content: center; gap: 0.5rem;
  color: rgba(232,220,200,0.2);
  font-size: 0.75rem; font-family: 'DM Mono', monospace;
}
.gallery-placeholder-icon { font-size: 2rem; }
.gallery-overlay {
  position: absolute; inset: 0;
  background: linear-gradient(to top, rgba(13,17,23,0.9) 0%, transparent 60%);
  opacity: 0; transition: opacity 0.3s ease;
  display: flex; align-items: flex-end; padding: 1rem 1.2rem;
}
.gallery-item-label {
  font-family: 'DM Mono', monospace; font-size: 0.6rem;
  letter-spacing: 0.1em; text-transform: uppercase;
  color: rgba(232,220,200,0.8); line-height: 1.4;
}
.gallery-location { color: var(--lime); font-size: 0.55rem; }

.gallery-empty {
  grid-column: 1/-1; text-align: center;
  padding: 5rem 2rem; color: rgba(232,220,200,0.2);
  font-family: 'DM Mono', monospace; font-size: 0.65rem;
  letter-spacing: 0.15em; text-transform: uppercase;
}

/* Lightbox */
.lightbox {
  position: fixed; inset: 0; z-index: 10000;
  background: rgba(13,17,23,0.96);
  display: flex; align-items: center; justify-content: center;
  opacity: 0; pointer-events: none;
  transition: opacity 0.3s ease;
}
.lightbox.open { opacity: 1; pointer-events: all; }
.lightbox-inner {
  position: relative; max-width: 90vw; max-height: 90vh;
  display: flex; flex-direction: column; align-items: center; gap: 1rem;
}
.lightbox-img {
  max-width: 90vw; max-height: 80vh;
  object-fit: contain; border-radius: 4px;
  box-shadow: 0 24px 80px rgba(0,0,0,0.8);
}
.lightbox-caption {
  font-family: 'DM Mono', monospace; font-size: 0.65rem;
  letter-spacing: 0.15em; text-transform: uppercase;
  color: rgba(232,220,200,0.5); text-align: center;
}
.lightbox-close {
  position: absolute; top: -2.5rem; right: 0;
  background: none; border: none; color: rgba(232,220,200,0.5);
  font-size: 1.5rem; cursor: pointer; padding: 0.5rem;
  transition: color 0.2s;
}
.lightbox-close:hover { color: var(--sand); }
.lightbox-nav {
  position: fixed; top: 50%; transform: translateY(-50%);
  background: rgba(255,255,255,0.08); border: none;
  color: var(--sand); font-size: 1.5rem; cursor: pointer;
  padding: 1rem 1.2rem; border-radius: 2px;
  transition: background 0.2s;
}
.lightbox-nav:hover { background: rgba(255,255,255,0.15); }
.lightbox-nav.prev { left: 1.5rem; }
.lightbox-nav.next { right: 1.5rem; }

/* Upload area */
.upload-area {
  display: none; flex-direction: column; align-items: center;
  justify-content: center; gap: 0.8rem;
  border: 2px dashed rgba(168,201,110,0.25);
  border-radius: 6px; padding: 3rem 2rem;
  text-align: center; cursor: pointer;
  transition: all 0.3s; margin-bottom: 1.5rem;
  background: rgba(168,201,110,0.03);
}
.upload-area.show { display: flex; }
.upload-area:hover, .upload-area.drag-over {
  border-color: rgba(168,201,110,0.5);
  background: rgba(168,201,110,0.07);
}
.upload-area-icon { font-size: 2.5rem; }
.upload-area-text {
  font-family: 'DM Mono', monospace; font-size: 0.65rem;
  letter-spacing: 0.12em; text-transform: uppercase;
  color: rgba(232,220,200,0.45); line-height: 1.8;
}
.upload-area-text strong { color: var(--lime); }

/* Upload form fields */
.upload-meta-form {
  display: none; gap: 0.8rem; flex-direction: column;
  padding: 1.5rem; background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.08); border-radius: 4px;
  margin-bottom: 1rem;
}
.upload-meta-form.show { display: flex; }
.umf-row { display: grid; grid-template-columns: 1fr 1fr; gap: 0.8rem; }
.umf-field { display: flex; flex-direction: column; gap: 0.4rem; }
.umf-label {
  font-family: 'DM Mono', monospace; font-size: 0.58rem;
  letter-spacing: 0.12em; text-transform: uppercase;
  color: rgba(232,220,200,0.4);
}
.umf-input {
  background: rgba(255,255,255,0.05); border: 1px solid rgba(255,255,255,0.1);
  border-radius: 3px; padding: 0.5rem 0.8rem;
  color: var(--sand); font-family: 'Outfit', sans-serif; font-size: 0.85rem;
  outline: none; transition: border-color 0.2s;
}
.umf-input:focus { border-color: rgba(168,201,110,0.4); }
.umf-select {
  background: #151B22; border: 1px solid rgba(255,255,255,0.1);
  border-radius: 3px; padding: 0.5rem 0.8rem;
  color: var(--sand); font-family: 'Outfit', sans-serif; font-size: 0.85rem;
  outline: none; transition: border-color 0.2s; cursor: pointer;
  -webkit-appearance: none; appearance: none;
}
.umf-select:focus { border-color: rgba(168,201,110,0.4); }
.umf-confirm-btn {
  align-self: flex-end;
  font-family: 'DM Mono', monospace; font-size: 0.62rem;
  letter-spacing: 0.12em; text-transform: uppercase;
  padding: 0.6rem 1.4rem; border-radius: 3px; border: none;
  background: var(--lime); color: var(--deep); cursor: pointer;
  transition: opacity 0.2s;
}
.umf-confirm-btn:hover { opacity: 0.85; }

/* ── PAST JOURNEY CARDS ─────────────────────── */
.past-section { padding: 8rem 5vw; }
.journey-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 2px; margin-top: 0.5rem; }
.journey-card {
  position: relative;
  background: rgba(122,175,196,0.05); border: 1px solid rgba(122,175,196,0.1);
  border-radius: 4px; overflow: hidden;
  opacity: 0; transform: translateY(24px);
  transition: opacity 0.5s ease, transform 0.5s ease, background 0.3s;
}
.journey-card:hover { background: rgba(122,175,196,0.09); }
.journey-card.visible { opacity: 1; transform: translateY(0); }
.journey-card.current-card { border-color: rgba(245,215,110,0.3); background: rgba(245,215,110,0.05); }
.journey-card.current-card:hover { background: rgba(245,215,110,0.09); }

.jc-header { padding: 1.6rem 1.8rem 1rem; display: flex; justify-content: space-between; align-items: flex-start; gap: 1rem; }
.jc-num { font-family: 'Playfair Display', serif; font-size: 3.5rem; font-weight: 900; line-height: 1; color: rgba(122,175,196,0.12); position: absolute; top: 0.8rem; right: 1.2rem; }
.current-card .jc-num { color: rgba(245,215,110,0.12); }
.jc-flag { font-size: 1.3rem; margin-bottom: 0.25rem; }
.jc-city { font-family: 'Playfair Display', serif; font-size: 1.25rem; font-weight: 700; line-height: 1.2; position: relative; z-index: 1; }
.jc-dates { font-family: 'DM Mono', monospace; font-size: 0.6rem; letter-spacing: 0.14em; text-transform: uppercase; color: rgba(122,175,196,0.6); margin-top: 0.3rem; }
.current-card .jc-dates { color: rgba(245,215,110,0.7); }
.jc-badge { flex-shrink: 0; font-family: 'DM Mono', monospace; font-size: 0.55rem; letter-spacing: 0.1em; text-transform: uppercase; padding: 0.3rem 0.6rem; border-radius: 2px; white-space: nowrap; margin-top: 0.2rem; }
.jc-badge.done { background: rgba(122,175,196,0.12); color: rgba(122,175,196,0.7); }
.jc-badge.now  { background: rgba(245,215,110,0.15); color: #F5D76E; }
.jc-body { padding: 0 1.8rem 1.6rem; display: flex; flex-direction: column; gap: 0.9rem; }
.jc-story { font-size: 0.83rem; line-height: 1.65; color: rgba(232,220,200,0.62); }
.jc-highlights { display: flex; flex-direction: column; gap: 0.35rem; }
.jc-hi { font-size: 0.8rem; color: rgba(232,220,200,0.7); display: flex; gap: 0.5rem; align-items: flex-start; line-height: 1.4; }
.jc-hi::before       { content: '→'; color: #7AAFC4; font-size: 0.65rem; margin-top: 0.18rem; flex-shrink: 0; }
.jc-hi.warn::before  { content: '⚠'; color: var(--rust); }
.jc-hi.star::before  { content: '★'; color: var(--lime); font-size: 0.65rem; }
.jc-hi.now::before   { content: '📍'; }

/* Hostel ratings */
.hostel-ratings { display: flex; flex-direction: column; gap: 0.5rem; margin-top: 0.3rem; }
.hostel-card { border-radius: 3px; padding: 0.7rem 0.9rem; display: flex; justify-content: space-between; align-items: center; gap: 0.8rem; }
.hostel-card.bad  { background: rgba(184,92,56,0.12);   border: 1px solid rgba(184,92,56,0.2); }
.hostel-card.good { background: rgba(168,201,110,0.1);  border: 1px solid rgba(168,201,110,0.2); }
.hostel-card.great { background: rgba(245,215,110,0.08); border: 1px solid rgba(245,215,110,0.2); }
.hostel-name { font-size: 0.78rem; font-weight: 500; line-height: 1.2; }
.hostel-meta { font-family: 'DM Mono', monospace; font-size: 0.58rem; letter-spacing: 0.06em; color: rgba(232,220,200,0.4); margin-top: 0.2rem; }
.hostel-stars { font-size: 0.75rem; flex-shrink: 0; text-align: right; line-height: 1.4; }
.hostel-price { font-family: 'DM Mono', monospace; font-size: 0.6rem; letter-spacing: 0.05em; color: rgba(232,220,200,0.4); display: block; margin-top: 0.1rem; }

/* Thailand budget bar */
.th-budget { background: rgba(122,175,196,0.06); border: 1px solid rgba(122,175,196,0.12); border-radius: 4px; padding: 2rem 2.5rem; margin-top: 3rem; display: grid; grid-template-columns: 1fr auto; gap: 2rem; align-items: center; }
.th-budget-title { font-family: 'DM Mono', monospace; font-size: 0.62rem; letter-spacing: 0.2em; text-transform: uppercase; color: rgba(122,175,196,0.6); margin-bottom: 0.5rem; }
.th-budget-bars { display: flex; flex-direction: column; gap: 0.6rem; }
.th-bar-row { display: grid; grid-template-columns: 120px 1fr 70px; gap: 0.8rem; align-items: center; }
.th-bar-label { font-size: 0.75rem; color: rgba(232,220,200,0.55); white-space: nowrap; }
.th-bar-track { height: 3px; background: rgba(255,255,255,0.06); border-radius: 2px; overflow: hidden; }
.th-bar-fill { height: 100%; border-radius: 2px; background: linear-gradient(90deg, #7AAFC4, #A8C96E); width: 0; transition: width 1.2s ease; }
.th-bar-num { font-family: 'DM Mono', monospace; font-size: 0.68rem; text-align: right; color: rgba(232,220,200,0.6); }
.th-total-box { text-align: right; }
.th-total-label { font-family: 'DM Mono', monospace; font-size: 0.6rem; letter-spacing: 0.15em; text-transform: uppercase; color: rgba(232,220,200,0.35); margin-bottom: 0.4rem; }
.th-total-num { font-family: 'Playfair Display', serif; font-size: 2.2rem; font-weight: 700; color: #7AAFC4; line-height: 1; }
.th-total-sub { font-family: 'DM Mono', monospace; font-size: 0.58rem; color: rgba(232,220,200,0.3); margin-top: 0.3rem; letter-spacing: 0.08em; }

/* ── PHASE CARDS ────────────────────────────── */
.phases { display: grid; gap: 2px; }
.phase-card { display: grid; grid-template-columns: 260px 1fr; min-height: 280px; border-radius: 4px; overflow: hidden; opacity: 0; transform: translateY(30px); transition: opacity 0.6s ease, transform 0.6s ease; }
.phase-card.visible { opacity: 1; transform: translateY(0); }
.phase-sidebar { padding: 2.5rem; display: flex; flex-direction: column; justify-content: space-between; position: relative; }
.phase-1 .phase-sidebar { background: var(--jungle); }
.phase-2 .phase-sidebar { background: #1C2E3A; }
.phase-3 .phase-sidebar { background: #2A1E10; }
.phase-4 .phase-sidebar { background: #1A1E2E; }
.phase-num { font-family: 'Playfair Display', serif; font-size: 5rem; font-weight: 900; line-height: 1; opacity: 0.12; position: absolute; top: 1rem; right: 1.5rem; }
.phase-dest { font-family: 'Playfair Display', serif; font-size: 1.6rem; font-weight: 700; line-height: 1.2; position: relative; z-index: 1; }
.phase-flag { font-size: 1.4rem; margin-bottom: 0.5rem; }
.phase-dates { font-family: 'DM Mono', monospace; font-size: 0.65rem; letter-spacing: 0.15em; text-transform: uppercase; color: rgba(232,220,200,0.5); margin-top: 0.5rem; }
.phase-duration { display: inline-block; background: rgba(255,255,255,0.08); border-radius: 2px; padding: 0.3rem 0.7rem; font-family: 'DM Mono', monospace; font-size: 0.65rem; letter-spacing: 0.1em; color: var(--lime); text-transform: uppercase; }
.phase-body { background: rgba(255,255,255,0.03); padding: 2.5rem 3rem; display: grid; grid-template-columns: 1fr 1fr; gap: 2rem; align-content: start; }
.phase-col-title { font-family: 'DM Mono', monospace; font-size: 0.6rem; letter-spacing: 0.2em; text-transform: uppercase; color: rgba(232,220,200,0.35); margin-bottom: 0.8rem; }
.activity-list { list-style: none; display: flex; flex-direction: column; gap: 0.5rem; }
.activity-list li { font-size: 0.88rem; color: rgba(232,220,200,0.75); display: flex; align-items: flex-start; gap: 0.6rem; line-height: 1.4; }
.activity-list li::before { content: '→'; color: var(--lime); font-size: 0.7rem; margin-top: 0.15rem; flex-shrink: 0; }
.activity-list li.adventure::before { content: '⚡'; }
.activity-list li.work::before { content: '💻'; }
.activity-list li.cave::before  { content: '🕳'; }

/* ── ADVENTURE CARDS ────────────────────────── */
.adventure-grid { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 2px; margin-top: 2px; }
.adv-card { background: rgba(255,255,255,0.03); padding: 2.5rem; position: relative; overflow: hidden; border-radius: 4px; opacity: 0; transform: translateY(20px); transition: opacity 0.5s ease, transform 0.5s ease, background 0.3s; }
.adv-card:hover { background: rgba(255,255,255,0.06); }
.adv-card.visible { opacity: 1; transform: translateY(0); }
.adv-icon { font-size: 2.5rem; margin-bottom: 1.5rem; display: block; }
.adv-card-title { font-family: 'Playfair Display', serif; font-size: 1.3rem; font-weight: 700; margin-bottom: 0.5rem; line-height: 1.2; }
.adv-location { font-family: 'DM Mono', monospace; font-size: 0.6rem; letter-spacing: 0.15em; text-transform: uppercase; color: var(--amber); margin-bottom: 1rem; }
.adv-desc { font-size: 0.85rem; line-height: 1.6; color: rgba(232,220,200,0.6); }
.adv-badge { position: absolute; top: 1.5rem; right: 1.5rem; background: var(--rust); color: white; font-family: 'DM Mono', monospace; font-size: 0.6rem; letter-spacing: 0.1em; text-transform: uppercase; padding: 0.3rem 0.6rem; border-radius: 2px; }
.adv-badge.highlight { background: var(--lime); color: var(--deep); }

/* ── BUDGET TABLE ───────────────────────────── */
.budget-section { background: rgba(168,201,110,0.04); border: 1px solid rgba(168,201,110,0.1); border-radius: 4px; padding: 3rem; margin-top: 2rem; }
.budget-row { display: grid; grid-template-columns: 180px 1fr 120px 120px 140px; gap: 1rem; padding: 1.2rem 0; border-bottom: 1px solid rgba(255,255,255,0.05); align-items: center; }
.budget-row.header { border-bottom: 1px solid rgba(168,201,110,0.2); padding-bottom: 1rem; margin-bottom: 0.5rem; }
.budget-row.header span { font-family: 'DM Mono', monospace; font-size: 0.6rem; letter-spacing: 0.2em; text-transform: uppercase; color: rgba(232,220,200,0.35); }
.budget-dest { font-family: 'Playfair Display', serif; font-size: 1rem; font-weight: 600; }
.budget-bar-wrap { height: 4px; background: rgba(255,255,255,0.06); border-radius: 2px; overflow: hidden; }
.budget-bar { height: 100%; border-radius: 2px; background: linear-gradient(90deg, var(--lime), var(--water)); transition: width 1s ease; width: 0; }
.budget-num { font-family: 'DM Mono', monospace; font-size: 0.85rem; text-align: right; }
.budget-total { margin-top: 1.5rem; padding-top: 1.5rem; border-top: 1px solid rgba(168,201,110,0.2); display: flex; justify-content: space-between; align-items: center; }
.budget-total-label { font-family: 'DM Mono', monospace; font-size: 0.65rem; letter-spacing: 0.2em; text-transform: uppercase; color: rgba(232,220,200,0.4); }
.budget-total-num { font-family: 'Playfair Display', serif; font-size: 2rem; font-weight: 700; color: var(--lime); }

/* ── TIMELINE ───────────────────────────────── */
.timeline { position: relative; padding-left: 2rem; }
.timeline::before { content: ''; position: absolute; left: 0; top: 0.5rem; bottom: 0; width: 1px; background: linear-gradient(to bottom, var(--lime), rgba(168,201,110,0.1)); }
.tl-item { position: relative; padding: 0 0 2.5rem 2rem; opacity: 0; transform: translateX(-10px); transition: opacity 0.5s ease, transform 0.5s ease; }
.tl-item.visible { opacity: 1; transform: translateX(0); }
.tl-dot { position: absolute; left: -0.4rem; top: 0.4rem; width: 9px; height: 9px; border-radius: 50%; background: var(--lime); border: 2px solid var(--deep); }
.tl-dot.adv { background: var(--amber); }
.tl-dot.fly { background: var(--water); }
.tl-date { font-family: 'DM Mono', monospace; font-size: 0.62rem; letter-spacing: 0.15em; text-transform: uppercase; color: rgba(232,220,200,0.35); margin-bottom: 0.3rem; }
.tl-title { font-size: 0.95rem; font-weight: 500; margin-bottom: 0.3rem; }
.tl-detail { font-size: 0.82rem; color: rgba(232,220,200,0.5); line-height: 1.5; }
.tl-type { display: inline-block; font-family: 'DM Mono', monospace; font-size: 0.55rem; letter-spacing: 0.1em; text-transform: uppercase; padding: 0.2rem 0.5rem; border-radius: 2px; margin-top: 0.4rem; }
.tl-type.adventure { background: rgba(212,135,10,0.15); color: var(--amber); }
.tl-type.flight    { background: rgba(59,122,140,0.15);  color: var(--water); }
.tl-type.work      { background: rgba(168,201,110,0.15); color: var(--lime); }
.tl-type.relax     { background: rgba(255,255,255,0.06); color: rgba(232,220,200,0.5); }

/* ── TIPS ───────────────────────────────────── */
.tips-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.5rem; margin-top: 1rem; }
.tip-card { background: rgba(255,255,255,0.03); border: 1px solid rgba(255,255,255,0.06); border-radius: 4px; padding: 1.8rem; opacity: 0; transform: translateY(15px); transition: opacity 0.4s ease, transform 0.4s ease; }
.tip-card.visible { opacity: 1; transform: translateY(0); }
.tip-icon { font-size: 1.5rem; margin-bottom: 1rem; display: block; }
.tip-title { font-family: 'DM Mono', monospace; font-size: 0.65rem; letter-spacing: 0.15em; text-transform: uppercase; color: var(--lime); margin-bottom: 0.6rem; }
.tip-text { font-size: 0.83rem; color: rgba(232,220,200,0.6); line-height: 1.6; }

/* ── MAP ────────────────────────────────────── */
.map-section { padding: 8rem 5vw; position: relative; }
.map-wrapper { position: relative; border-radius: 8px; overflow: hidden; border: 1px solid rgba(168,201,110,0.15); margin-top: 2rem; }
#travel-map { height: 600px; width: 100%; background: #0D1117; }
.map-legend { display: flex; gap: 1.5rem; margin-top: 1.2rem; flex-wrap: wrap; }
.legend-item { display: flex; align-items: center; gap: 0.5rem; font-family: 'DM Mono', monospace; font-size: 0.62rem; letter-spacing: 0.1em; text-transform: uppercase; color: rgba(232,220,200,0.5); }
.legend-dot { width: 10px; height: 10px; border-radius: 50%; flex-shrink: 0; }

/* Leaflet overrides */
.leaflet-popup-content-wrapper { background: #151B22 !important; border: 1px solid rgba(168,201,110,0.25) !important; border-radius: 6px !important; box-shadow: 0 8px 32px rgba(0,0,0,0.6) !important; color: #E8DCC8 !important; font-family: 'Outfit', sans-serif !important; padding: 0 !important; }
.leaflet-popup-content { margin: 0 !important; padding: 0 !important; width: 240px !important; }
.leaflet-popup-tip { background: #151B22 !important; }
.leaflet-popup-close-button { color: rgba(232,220,200,0.4) !important; font-size: 1rem !important; top: 8px !important; right: 10px !important; }
.popup-inner { padding: 1.2rem 1.4rem; }
.popup-type { font-family: 'DM Mono', monospace; font-size: 0.55rem; letter-spacing: 0.18em; text-transform: uppercase; margin-bottom: 0.4rem; }
.popup-title { font-family: 'Playfair Display', serif; font-size: 1.1rem; font-weight: 700; line-height: 1.2; margin-bottom: 0.3rem; color: #E8DCC8; }
.popup-dates { font-family: 'DM Mono', monospace; font-size: 0.58rem; letter-spacing: 0.1em; color: rgba(232,220,200,0.4); margin-bottom: 0.7rem; }
.popup-desc { font-size: 0.78rem; line-height: 1.55; color: rgba(232,220,200,0.65); }
.popup-tags { display: flex; flex-wrap: wrap; gap: 0.3rem; margin-top: 0.8rem; }
.popup-tag { font-family: 'DM Mono', monospace; font-size: 0.5rem; letter-spacing: 0.08em; text-transform: uppercase; padding: 0.2rem 0.5rem; border-radius: 2px; background: rgba(255,255,255,0.07); color: rgba(232,220,200,0.5); }
.leaflet-tile { filter: brightness(0.85) saturate(0.7) hue-rotate(195deg); }

/* ── FOOTER ─────────────────────────────────── */
footer { padding: 3rem 5vw; display: flex; justify-content: space-between; align-items: center; border-top: 1px solid rgba(255,255,255,0.06); flex-wrap: wrap; gap: 1rem; }
.footer-title { font-family: 'Playfair Display', serif; font-size: 1.1rem; font-weight: 700; }
.footer-dates { font-family: 'DM Mono', monospace; font-size: 0.62rem; letter-spacing: 0.12em; text-transform: uppercase; color: rgba(232,220,200,0.35); margin-top: 0.4rem; }
.return-badge { font-family: 'DM Mono', monospace; font-size: 0.65rem; letter-spacing: 0.15em; text-transform: uppercase; padding: 0.6rem 1.2rem; border-radius: 2px; border: 1px solid rgba(184,92,56,0.3); color: var(--rust); }

/* ── ANIMATIONS ─────────────────────────────── */
@keyframes fadeUp  { from { opacity:0; transform:translateY(20px); } to { opacity:1; transform:translateY(0); } }
@keyframes pulse-ring {
  0%   { box-shadow: 0 0 0 0 rgba(168,201,110,0.5), 0 3px 12px rgba(0,0,0,0.5); }
  70%  { box-shadow: 0 0 0 10px rgba(168,201,110,0), 0 3px 12px rgba(0,0,0,0.5); }
  100% { box-shadow: 0 0 0 0 rgba(168,201,110,0),  0 3px 12px rgba(0,0,0,0.5); }
}
@keyframes pulse-subtle {
  0%, 100% { opacity: 1; }
  50%       { opacity: 0.75; }
}

/* ── RESPONSIVE ─────────────────────────────── */
@media (max-width: 900px) {
  .journey-grid, .adventure-grid, .tips-grid { grid-template-columns: 1fr; }
  .th-budget { grid-template-columns: 1fr; }
  .phase-card { grid-template-columns: 1fr; }
  .phase-body { grid-template-columns: 1fr; }
  .gallery-grid { grid-template-columns: 1fr 1fr; }
  .budget-row { grid-template-columns: 1fr 1fr; }
  .hero-stats { gap: 1.5rem; flex-wrap: wrap; }
}
@media (max-width: 600px) {
  .gallery-grid { grid-template-columns: 1fr; }
  .umf-row { grid-template-columns: 1fr; }
}
