/* ==========================================================================
   WildLanka Safari — Design Tokens
   ========================================================================== */
:root{
  --canopy:        #F7F2E9; /* main bg — warm sand/ivory */
  --canopy-dark:    #EDE3D1; /* slightly deeper panels — sandstone */
  --foliage:        #E3D4B9; /* mid tone, cards — dune */
  --foliage-light:  #D8C5A2;
  --ochre:          #B8772E; /* primary accent — sun-baked savanna gold, deepened for contrast on light bg */
  --ochre-soft:     #9C5F22;
  --rust:           #8A3B22; /* secondary accent, sparing — laterite/terracotta */
  --parchment:      #2C1F14; /* main text — dark umber, reads on light bg */
  --parchment-dim:  #6B5B47;
  --line:           rgba(44,31,20,0.14);
  --on-accent:      #FBF6EC; /* text/icons placed on top of ochre/rust fills */

  --font-display: 'Fraunces', Georgia, serif;
  --font-body:    'Jost', 'Helvetica Neue', Arial, sans-serif;

  --container: 1180px;
  --radius: 2px;
}

*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body.wildlanka{
  margin:0;
  background:var(--canopy);
  color:var(--parchment);
  font-family:var(--font-body);
  font-size:16px;
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{max-width:100%;display:block;}
a{color:inherit;text-decoration:none;}
.container{max-width:var(--container);margin:0 auto;padding:0 24px;}
.eyebrow{
  display:inline-block;
  font-family:var(--font-body);
  letter-spacing:.22em;
  text-transform:uppercase;
  font-size:12.5px;
  color:var(--ochre);
  margin-bottom:14px;
  font-weight:500;
}
h1,h2,h3,h4{
  font-family:var(--font-display);
  font-weight:500;
  line-height:1.14;
  margin:0 0 18px;
  color:var(--parchment);
}
h1{font-size:clamp(38px,5vw,64px); font-weight:400;}
h2{font-size:clamp(28px,3.4vw,42px);}
h3{font-size:22px;}
p{color:var(--parchment-dim); margin:0 0 16px;}
.btn{
  display:inline-flex;
  align-items:center;
  gap:10px;
  padding:14px 30px;
  border:1px solid var(--ochre);
  color:var(--ochre);
  font-family:var(--font-body);
  letter-spacing:.14em;
  text-transform:uppercase;
  font-size:12.5px;
  font-weight:500;
  border-radius:var(--radius);
  transition:background .25s ease,color .25s ease;
  cursor:pointer;
  background:transparent;
}
.btn:hover{background:var(--ochre); color:var(--on-accent);}
.btn.solid{background:var(--ochre); color:var(--on-accent);}
.btn.solid:hover{background:var(--ochre-soft);}

/* ===== Site Header ===== */
.site-header{
  position:absolute; top:0; left:0; right:0; z-index:50;
  padding:28px 0;
}
.site-header.is-solid{
  position:sticky;
  background:var(--canopy-dark);
  border-bottom:1px solid var(--line);
  padding:18px 0;
}
.header-inner{display:flex; align-items:center; justify-content:space-between;}
.logo{
  font-family:var(--font-display);
  font-size:20px; letter-spacing:.05em; color:var(--parchment);
}
.logo span{color:var(--ochre);}
.main-nav ul{display:flex; gap:34px; list-style:none; margin:0; padding:0;}
.main-nav a{
  font-size:13px; letter-spacing:.12em; text-transform:uppercase;
  color:var(--parchment-dim); transition:color .2s;
}
.main-nav a:hover, .main-nav a.current{color:var(--ochre);}
.nav-toggle{
  display:none; background:none; border:none; color:var(--parchment); font-size:24px;
  z-index:60; line-height:1; cursor:pointer; padding:4px;
}
.nav-toggle .icon-close{display:none;}
.nav-toggle.is-open .icon-open{display:none;}
.nav-toggle.is-open .icon-close{display:inline;}
body.nav-open{overflow:hidden;}

/* ===== Hero ===== */
.hero{
  position:relative;
  min-height:92vh;
  display:flex; align-items:center; justify-content:center; text-align:center;
  overflow:hidden;
  background:linear-gradient(180deg,var(--canopy-dark) 0%, var(--canopy) 60%);
}
.hero-media{
  position:absolute; inset:0; z-index:0;
}
.hero-media .ph-block{width:100%;height:100%;}
.hero-media::after{
  content:none;
}
.hero-content{position:relative; z-index:2; max-width:760px; padding:0 24px;}
.hero-content .eyebrow{display:none;}
.hero-content h1{margin-bottom:28px;}
.hero-content h1 em{font-style:italic; color:var(--ochre-soft);}
.scroll-cue{
  position:absolute; bottom:34px; left:50%; transform:translateX(-50%);
  z-index:2; display:flex; flex-direction:column; align-items:center; gap:8px;
  font-size:11px; letter-spacing:.2em; text-transform:uppercase; color:var(--parchment-dim);
}
.scroll-cue .line{width:1px;height:38px;background:var(--ochre);animation:scrollLine 1.8s ease-in-out infinite;}
@keyframes scrollLine{0%{transform:scaleY(0);transform-origin:top;}50%{transform:scaleY(1);transform-origin:top;}51%{transform-origin:bottom;}100%{transform:scaleY(0);transform-origin:bottom;}}

/* ===== Placeholder media blocks (swap-out zones) ===== */
.ph-block{
  position:relative;
  background:
    repeating-linear-gradient(135deg, rgba(184,119,46,.12) 0 2px, transparent 2px 14px),
    linear-gradient(160deg,var(--foliage) 0%, var(--foliage-light) 100%);
  display:flex; align-items:center; justify-content:center;
  color:var(--parchment-dim);
  border:1px dashed rgba(184,119,46,.45);
  min-height:160px;
  text-align:center;
}
.ph-block .ph-label{
  font-family:var(--font-body); font-size:11px; letter-spacing:.12em; text-transform:uppercase;
  padding:10px 14px; line-height:1.5;
}
.ph-block .ph-label small{display:block; color:var(--ochre); margin-top:4px; font-size:10.5px;}

/* ===== Section Spacing ===== */
.section{padding:110px 0;}
.section.tight{padding:70px 0;}
.section-head{max-width:640px; margin:0 0 56px;}
.section-head.center{margin:0 auto 56px; text-align:center;}

/* ===== Trail / Reasons section (signature element) ===== */
.trail{position:relative;}
.trail-path{
  position:absolute; left:50%; top:40px; bottom:40px; width:1px;
  background-image:linear-gradient(var(--ochre) 60%, transparent 0%);
  background-size:1px 14px;
  opacity:.5;
  display:none;
}
.trail-item{
  display:grid; grid-template-columns:1fr 1fr; gap:50px; align-items:center;
  margin-bottom:64px;
}
.trail-item:nth-child(even) .trail-media{order:2;}
.trail-media .ph-block{aspect-ratio:1/1; transform:rotate(3deg);}
.trail-item:nth-child(even) .trail-media .ph-block{transform:rotate(-3deg);}
.trail-mark{
  display:inline-flex; align-items:center; gap:10px;
  color:var(--ochre); font-family:var(--font-body); font-size:12px; letter-spacing:.16em; text-transform:uppercase; margin-bottom:10px;
}
.trail-mark .num{font-family:var(--font-display); font-size:22px; color:var(--parchment);}

/* ===== Park cards ===== */
.park-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:28px;}
.park-card{
  background:var(--canopy-dark);
  border:1px solid var(--line);
  overflow:hidden;
  transition:transform .3s ease, border-color .3s ease;
}
.park-card:hover{transform:translateY(-6px); border-color:var(--ochre);}
.park-card .ph-block{aspect-ratio:4/3;}
.park-card-body{padding:26px 26px 30px;}
.park-card-body .badge{
  display:inline-block; font-size:11px; letter-spacing:.14em; text-transform:uppercase;
  color:var(--on-accent); background:var(--ochre); padding:5px 10px; margin-bottom:14px;
}
.park-card-body h3{margin-bottom:8px;}
.park-card-body .meta{font-size:13px; color:var(--parchment-dim); display:flex; gap:16px; margin-top:14px;}

/* ===== Tour / Itinerary list rows (reference-style) ===== */
.tour-rows{border-top:1px solid var(--line);}
.tour-row{
  display:grid; grid-template-columns:110px 1fr auto; gap:24px; align-items:center;
  padding:26px 0; border-bottom:1px solid var(--line);
}
.tour-row.is-active{background:var(--ochre); border-color:var(--ochre);}
.tour-row.is-active *{color:var(--on-accent) !important;}
.tour-row .date{font-family:var(--font-display); font-size:15px; color:var(--ochre); letter-spacing:.02em;}
.tour-row.is-active .date{color:var(--on-accent);}
.tour-row h4{margin:0 0 6px; font-size:18px; font-family:var(--font-display); font-weight:500;}
.tour-row p{margin:0; font-size:14px;}
.tour-row .view-link{font-size:12px; letter-spacing:.12em; text-transform:uppercase; color:var(--parchment-dim); white-space:nowrap; display:flex; align-items:center; gap:8px;}
.tour-row.is-active .view-link{color:var(--on-accent);}

/* ===== Itinerary day blocks ===== */
.itin-day{
  display:grid; grid-template-columns:90px 1fr; gap:30px;
  padding:34px 0; border-bottom:1px solid var(--line);
}
.itin-day .day-num{font-family:var(--font-display); font-size:34px; color:var(--ochre);}
.itin-day .day-num span{display:block; font-family:var(--font-body); font-size:11px; letter-spacing:.14em; color:var(--parchment-dim); text-transform:uppercase; margin-top:6px;}
.itin-day h4{margin-bottom:10px;}

/* ===== FAQ accordion ===== */
.faq-list{max-width:760px;}
.faq-item{border-bottom:1px solid var(--line);}
.faq-q{
  width:100%; text-align:left; background:none; border:none; color:var(--parchment);
  font-family:var(--font-display); font-size:18px; padding:24px 0; cursor:pointer;
  display:flex; justify-content:space-between; align-items:center; gap:20px;
}
.faq-q .icon{color:var(--ochre); font-size:20px; transition:transform .25s;}
.faq-item.open .faq-q .icon{transform:rotate(45deg);}
.faq-a{max-height:0; overflow:hidden; transition:max-height .3s ease;}
.faq-a p{padding-bottom:22px; margin:0;}

/* ===== Gallery (diamond-inspired but adapted: track-card masonry) ===== */
.gallery-grid{
  display:grid; grid-template-columns:repeat(4,1fr); gap:18px;
}
.gallery-grid .ph-block{aspect-ratio:1/1;}
.gallery-grid .g-tall{grid-row:span 2;}
.gallery-grid .g-tall .ph-block{aspect-ratio:auto; height:100%;}
.gallery-filter{display:flex; gap:10px; margin-bottom:40px; flex-wrap:wrap;}
.gallery-filter button{
  background:none; border:1px solid var(--line); color:var(--parchment-dim);
  padding:9px 18px; font-size:12px; letter-spacing:.12em; text-transform:uppercase; cursor:pointer; transition:all .2s;
}
.gallery-filter button.active, .gallery-filter button:hover{border-color:var(--ochre); color:var(--ochre);}

/* ===== Stats strip ===== */
.stats-strip{display:flex; justify-content:space-between; border-top:1px solid var(--line); border-bottom:1px solid var(--line); padding:40px 0;}
.stat{text-align:center;}
.stat .num{font-family:var(--font-display); font-size:38px; color:var(--ochre);}
.stat .label{font-size:12px; letter-spacing:.12em; text-transform:uppercase; color:var(--parchment-dim); margin-top:6px;}

/* ===== Footer ===== */
.site-footer{background:var(--canopy-dark); padding:80px 0 30px; border-top:1px solid var(--line);}
.footer-grid{display:grid; grid-template-columns:1.4fr 1fr 1fr 1fr; gap:50px; margin-bottom:60px;}
.footer-grid h5{font-family:var(--font-body); font-size:12.5px; letter-spacing:.14em; text-transform:uppercase; color:var(--ochre); margin-bottom:18px;}
.footer-grid ul{list-style:none; margin:0; padding:0;}
.footer-grid li{margin-bottom:10px;}
.footer-grid a{color:var(--parchment-dim); font-size:14px;}
.footer-grid a:hover{color:var(--ochre);}
.footer-bottom{
  border-top:1px solid var(--line); padding-top:26px; display:flex; justify-content:space-between;
  font-size:13px; color:var(--parchment-dim);
}

/* ===== Page header (for inner pages) ===== */
.page-header{padding:200px 0 80px; text-align:center; position:relative; background:var(--canopy-dark);}
.page-header .ph-block{position:absolute; inset:0; opacity:.25; z-index:0;}
.page-header .container{position:relative; z-index:1;}

/* ===== Responsive ===== */

/* Tablet / small desktop */
@media (max-width:980px){
  .park-grid{grid-template-columns:1fr 1fr;}
  .footer-grid{grid-template-columns:1fr 1fr;}
  .gallery-grid{grid-template-columns:repeat(2,1fr);}
  .trail-item{gap:32px;}
  .section{padding:80px 0;}
}

/* Mobile (phones + small tablets in portrait) */
@media (max-width:760px){
  .container{padding:0 20px;}

  /* --- Mobile nav --- */
  .nav-toggle{display:block;}
  .main-nav{
    display:block;
    position:fixed;
    top:0; right:0;
    width:min(78vw,320px);
    height:100vh;
    height:100dvh;
    background:var(--canopy-dark);
    border-left:1px solid var(--line);
    padding:90px 30px 30px;
    transform:translateX(100%);
    transition:transform .3s ease;
    overflow-y:auto;
    z-index:58;
  }
  .main-nav.is-open{transform:translateX(0);}
  .main-nav ul{flex-direction:column; gap:8px;}
  .main-nav li{border-bottom:1px solid var(--line);}
  .main-nav a{display:block; padding:14px 0; font-size:14px;}
  .nav-scrim{
    display:none; position:fixed; inset:0; z-index:55;
    background:rgba(44,31,20,.45);
  }
  .nav-scrim.is-open{display:block;}

  .header-inner .btn{padding:11px 20px; font-size:11.5px;}

  /* --- Hero --- */
  .hero{min-height:78vh; min-height:78svh; padding-top:90px;}
  .hero-content{padding:0 20px;}

  /* --- Trail / reasons --- */
  .trail-item, .trail-item:nth-child(even){grid-template-columns:1fr; gap:24px; margin-bottom:48px;}
  .trail-item:nth-child(even) .trail-media{order:0;}
  .trail-media .ph-block{transform:none !important; max-width:88%; margin:0 auto;}

  /* --- Park cards --- */
  .park-grid{grid-template-columns:1fr; gap:20px;}

  /* --- Tour rows --- */
  .tour-row{grid-template-columns:1fr; text-align:left; gap:8px; padding:20px 0;}

  /* --- Stats strip --- */
  .stats-strip{flex-wrap:wrap; gap:28px 18px; justify-content:flex-start; padding:32px 0;}
  .stat{flex:1 1 calc(50% - 18px); text-align:left;}
  .stat .num{font-size:30px;}

  /* --- Itinerary --- */
  .itin-day{grid-template-columns:1fr; gap:14px; padding:26px 0;}

  /* --- Gallery --- */
  .gallery-grid{grid-template-columns:repeat(2,1fr); gap:12px;}
  .gallery-filter{gap:8px;}
  .gallery-filter button{padding:8px 14px; font-size:11px;}

  /* --- Footer --- */
  .footer-grid{grid-template-columns:1fr; gap:36px; margin-bottom:40px;}
  .footer-bottom{flex-direction:column; gap:10px; text-align:left;}

  /* --- Section spacing --- */
  .section{padding:60px 0;}
  .section.tight{padding:44px 0;}
  .section-head{margin-bottom:36px;}
  .section-head.center{margin:0 auto 36px;}

  /* --- Page header (inner pages) --- */
  .page-header{padding:130px 0 50px;}
}

/* Small phones */
@media (max-width:420px){
  .container{padding:0 16px;}
  h1{font-size:clamp(30px,9vw,40px);}
  .btn{padding:12px 22px; font-size:11.5px;}
  .gallery-grid{grid-template-columns:1fr 1fr; gap:10px;}
  .stat{flex:1 1 100%;}
  .stats-strip{gap:18px;}
  .trail-mark .num{font-size:18px;}
  .tour-row .date{font-size:13px;}
}
