/* ==========================================================================
   Danum Valley — Shared Stylesheet
   Design tokens + components used across every page.
   ========================================================================== */

:root{
  --canopy-950:#16241A;
  --canopy-900:#1E301F;
  --moss-700:#4A5D3A;
  --moss-500:#6B7D5E;
  --mist-100:#F6F3E9;
  --bg:#FFFFFF;
  --clay-500:#B4622C;
  --clay-600:#9A4F22;
  --amber-500:#B4801F;
  --line:rgba(22,36,26,0.12);
  --line-soft:rgba(22,36,26,0.08);
}

*{box-sizing:border-box; margin:0; padding:0;}
html{scroll-behavior:smooth; background:#FFFFFF; color-scheme:light;}
body{
  font-family:'Public Sans', sans-serif;
  background:var(--bg);
  color:var(--canopy-950);
  -webkit-font-smoothing:antialiased;
  color-scheme:light;
}
h1,h2,h3{font-family:'Fraunces', serif; font-weight:600; letter-spacing:-0.01em;}
.mono{font-family:'IBM Plex Mono', monospace;}
.wrap{max-width:1180px; margin:0 auto; padding:0 32px;}
a{color:inherit; text-decoration:none;}
img{max-width:100%; display:block;}

/* Hard override so iOS/Safari auto-dark-mode never re-darkens the page */
@media (prefers-color-scheme: dark){
  html, body, section, .hero, .nav, footer, .about-wrap,
  .stat-band, .wildlife, #guides, .cta-band, .route,
  .page-hero, .content, .sidebar, .faq, .related{
    background-color:#FFFFFF !important;
  }
  .wildlife, .stat-band, #guides, .cta-band, .route, .info-box{
    background-color:#F6F3E9 !important;
  }
}

/* ---------- NAV (shared across every page) ---------- */
.nav{
  position:sticky; top:0; z-index:50;
  background:rgba(255,255,255,0.94);
  backdrop-filter:blur(8px);
  border-bottom:1px solid var(--line);
}
.nav .wrap{
  display:flex; align-items:center; justify-content:space-between;
  height:74px; color:var(--canopy-950);
}
.nav-logo{
  font-family:'Fraunces', serif; font-size:19px; font-weight:600;
  letter-spacing:0.02em; text-transform:uppercase;
  display:flex; align-items:center; gap:10px;
}
.nav-logo .mark{
  width:9px; height:9px; border-radius:50%;
  background:var(--clay-500); display:inline-block;
}
.nav-links{display:flex; align-items:center; gap:34px; font-size:14.5px; font-weight:500;}
.nav-links a{opacity:0.75; transition:opacity .15s;}
.nav-links a:hover, .nav-links a.active{opacity:1;}
.nav-cta{
  background:var(--clay-500); color:#fff;
  padding:10px 20px; border-radius:2px; font-size:13.5px; font-weight:600;
  letter-spacing:0.02em; white-space:nowrap;
}
.nav-cta:hover{background:var(--clay-600);}

@media (max-width:900px){ .nav-links{display:none;} }

/* ---------- BUTTONS ---------- */
.btn-primary{
  display:inline-block;
  background:var(--clay-500); color:#fff;
  padding:15px 28px; font-size:14.5px; font-weight:600;
  letter-spacing:0.02em; border-radius:2px;
}
.btn-primary:hover{background:var(--clay-600);}
.btn-ghost{
  display:inline-block;
  border:1px solid var(--line); color:var(--canopy-950);
  padding:15px 28px; font-size:14.5px; font-weight:600; border-radius:2px;
}
.btn-ghost:hover{border-color:var(--canopy-950);}

/* ---------- BREADCRUMB (content pages) ---------- */
.breadcrumb{
  padding:22px 0 0;
  font-size:12.5px; color:var(--moss-700);
  display:flex; gap:8px; align-items:center;
}
.breadcrumb a{opacity:0.75;}
.breadcrumb a:hover{opacity:1; color:var(--clay-500);}

/* ---------- PAGE HERO (small banner, content pages) ---------- */
.page-hero{padding:28px 0 56px;}
.page-hero .eyebrow{
  font-size:12.5px; letter-spacing:0.14em; text-transform:uppercase;
  color:var(--clay-500); font-weight:600; margin-bottom:16px;
}
.page-hero h1{font-size:clamp(32px,4.6vw,52px); line-height:1.06; max-width:780px;}
.page-hero .sub{
  margin-top:18px; font-size:16.5px; line-height:1.65; color:var(--moss-700);
  max-width:640px;
}
.page-hero .meta{
  margin-top:26px; display:flex; gap:28px; flex-wrap:wrap;
  border-top:1px solid var(--line); padding-top:18px;
}
.page-hero .meta div{font-size:12px; color:var(--moss-700);}
.page-hero .meta b{display:block; color:var(--canopy-950); font-size:14px; margin-top:3px;}

/* ---------- CONTENT LAYOUT (article + sidebar) ---------- */
.content-layout{
  display:grid; grid-template-columns:1fr 320px; gap:64px;
  padding:0 0 100px;
}
@media (max-width:900px){ .content-layout{grid-template-columns:1fr;} }

.content{font-size:16.5px; line-height:1.75; color:var(--canopy-900);}
.content h2{font-size:26px; margin:44px 0 16px; color:var(--canopy-950);}
.content h2:first-child{margin-top:0;}
.content h3{font-size:19px; margin:30px 0 12px; color:var(--canopy-950);}
.content p{margin-bottom:18px; opacity:0.88;}
.content ul, .content ol{margin:0 0 20px 22px;}
.content li{margin-bottom:8px; opacity:0.88;}
.content strong{color:var(--canopy-950);}
.content .lead{font-size:19px; color:var(--moss-700); margin-bottom:8px;}

.photo-block{ aspect-ratio:16/9; border-radius:3px; border:1px solid var(--line); margin:28px 0; position:relative; overflow:hidden; } .photo-block img{ width:100%; height:100%; display:block; object-fit:cover; /* Fill the container while maintaining aspect ratio */ object-position:center; /* Center the image */ } .photo-block span{ position:absolute; bottom:0; left:0; right:0; padding:12px 16px; font-size:11px; color:var(--moss-700); font-family:'IBM Plex Mono', monospace; z-index:2; }

.info-box{
  background:var(--mist-100); border:1px solid var(--line); border-radius:3px;
  padding:22px 24px; margin:28px 0;
}
.info-box .kicker{
  font-size:11.5px; letter-spacing:0.06em; text-transform:uppercase;
  color:var(--clay-500); font-weight:600; margin-bottom:10px;
}
.info-box p{margin-bottom:0; font-size:15px;}
.info-box p + p{margin-top:10px;}

table.data-table{width:100%; border-collapse:collapse; margin:24px 0; font-size:14.5px;}
table.data-table th, table.data-table td{
  text-align:left; padding:12px 14px; border-bottom:1px solid var(--line);
}
table.data-table th{
  font-family:'IBM Plex Mono',monospace; font-size:11.5px; letter-spacing:0.03em;
  text-transform:uppercase; color:var(--moss-700); font-weight:500;
}
table.data-table td b{color:var(--canopy-950);}

.route-mini{
  display:flex; align-items:center; justify-content:space-between; gap:10px;
  background:var(--mist-100); border:1px solid var(--line); border-radius:3px;
  padding:28px 24px; margin:28px 0; flex-wrap:wrap;
}
.route-mini .stop{text-align:center; flex:1; min-width:110px;}
.route-mini .stop .dot{width:9px; height:9px; border-radius:50%; background:var(--clay-500); margin:0 auto 8px;}
.route-mini .stop b{display:block; font-family:'Fraunces',serif; font-size:15.5px; margin-bottom:3px;}
.route-mini .stop span{font-size:11px; color:var(--moss-700); font-family:'IBM Plex Mono',monospace;}
.route-mini .arrow{font-family:'IBM Plex Mono',monospace; font-size:11px; color:var(--moss-700);}

/* ---------- SIDEBAR ---------- */
.sidebar{padding-top:2px;}
.sidebar-card{
  border:1px solid var(--line); border-radius:3px; padding:26px 22px;
  position:sticky; top:100px;
}
.sidebar-card h3{font-size:18px; margin-bottom:10px;}
.sidebar-card p{font-size:14px; color:var(--moss-700); line-height:1.6; margin-bottom:18px;}
.sidebar-card .btn-primary{width:100%; text-align:center; margin-bottom:10px;}
.sidebar-card .btn-ghost{width:100%; text-align:center;}
.sidebar-list{margin-top:28px; border-top:1px solid var(--line); padding-top:22px;}
.sidebar-list .kicker{
  font-size:11.5px; letter-spacing:0.06em; text-transform:uppercase;
  color:var(--clay-500); font-weight:600; margin-bottom:14px;
}
.sidebar-list a{
  display:block; font-size:14px; padding:10px 0; border-bottom:1px solid var(--line-soft);
  color:var(--canopy-900);
}
.sidebar-list a:hover{color:var(--clay-500);}

/* ---------- FAQ ---------- */
.faq{padding:80px 0; background:var(--mist-100); border-top:1px solid var(--line); border-bottom:1px solid var(--line);}
.faq .section-head{max-width:640px; margin-bottom:44px;}
.faq-item{border-bottom:1px solid var(--line); padding:22px 0;}
.faq-item h3{font-size:17px; margin-bottom:10px; font-weight:600; font-family:'Public Sans',sans-serif;}
.faq-item p{font-size:15px; line-height:1.65; color:var(--moss-700);}

/* ---------- RELATED GUIDES ---------- */
.related{padding:80px 0;}
.related .section-head{max-width:640px; margin-bottom:44px;}
.related-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:28px;}
@media (max-width:900px){ .related-grid{grid-template-columns:1fr;} }
.rcard{border-top:2px solid var(--canopy-950); padding-top:18px;}
.rcard .photo{ aspect-ratio:16/10; margin-bottom:16px; border-radius:3px; border:1px solid var(--line); overflow:hidden; position:relative; } .rcard .photo img{ width:100%; height:100%; display:block; object-fit:cover; /* Fills the container while maintaining aspect ratio */ object-position:center; /* Centers the image */ }
.rcard .cat{font-size:11.5px; letter-spacing:0.06em; text-transform:uppercase; color:var(--clay-500); font-weight:600;}
.rcard h3{font-size:18px; margin:8px 0 8px; line-height:1.25;}
.rcard p{font-size:13.5px; color:var(--moss-700); line-height:1.55;}

/* ---------- GENERIC SECTION HEAD ---------- */
.eyebrow{
  font-size:12.5px; letter-spacing:0.14em; text-transform:uppercase;
  color:var(--clay-500); font-weight:600; margin-bottom:14px;
}
.section-head h2{font-size:clamp(26px,3.2vw,38px); line-height:1.1;}
.section-head p{margin-top:14px; font-size:15.5px; line-height:1.6; color:var(--moss-700);}

/* ---------- CTA BAND (shared) ---------- */
.cta-band{
  background:var(--mist-100);
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
  color:var(--canopy-950);
  padding:80px 0; text-align:center;
}
.cta-band h2{font-size:clamp(28px,4vw,44px); margin-bottom:18px;}
.cta-band p{font-size:16px; color:var(--moss-700); max-width:520px; margin:0 auto 32px;}

/* ---------- FOOTER (shared) ---------- */
footer{background:var(--bg); color:var(--moss-700); padding:64px 0 32px;}
.foot-grid{display:grid; grid-template-columns:1.4fr 1fr 1fr 1fr; gap:40px; padding-bottom:48px; border-bottom:1px solid var(--line);}
.foot-grid h4{font-size:13px; letter-spacing:0.04em; text-transform:uppercase; color:var(--canopy-950); margin-bottom:18px; font-weight:600;}
.foot-grid a{display:block; font-size:14px; margin-bottom:10px; opacity:0.85;}
.foot-grid a:hover{opacity:1; color:var(--clay-500);}
.foot-logo{font-family:'Fraunces',serif; font-size:20px; color:var(--canopy-950); margin-bottom:14px;}
.foot-grid p{font-size:13.5px; line-height:1.6; max-width:280px;}
.foot-bottom{
  display:flex; justify-content:space-between; padding-top:28px;
  font-size:12px; flex-wrap:wrap; gap:10px;
}
@media (max-width:900px){ .foot-grid{grid-template-columns:1fr 1fr;} }

/* ==========================================================================
   Homepage-only components
   ========================================================================== */

.hero{position:relative; background:var(--bg); color:var(--canopy-950); padding-top:64px;}
.hero-eyebrow{
  font-size:13px; letter-spacing:0.14em; text-transform:uppercase;
  color:var(--clay-500); font-weight:600; margin-bottom:22px;
  display:flex; align-items:center; gap:10px;
}
.hero h1{font-size:clamp(38px, 5.6vw, 76px); line-height:1.02; max-width:880px; font-weight:600; color:var(--canopy-950);}
.hero h1 em{font-style:italic; font-weight:400; color:var(--clay-500);}
.hero-sub{max-width:540px; margin-top:26px; font-size:17px; line-height:1.65; color:var(--moss-700);}
.hero-actions{display:flex; gap:16px; margin-top:36px; flex-wrap:wrap;}
.hero-photo{ margin-top:56px; aspect-ratio:21/9; border-radius:3px; border:1px solid var(--line); background:linear-gradient(140deg,#EDEADC 0%, #E4E9DA 45%, #DCE4D3 100%); position:relative; display:flex; align-items:flex-end; } .hero-photo span{padding:14px 18px; font-size:11.5px; color:var(--moss-700); font-family:'IBM Plex Mono',monospace; letter-spacing:0.02em;}

.field-tag{
  margin-top:52px; border-top:1px solid var(--line); border-bottom:1px solid var(--line);
  padding:22px 0; display:grid; grid-template-columns:repeat(4,1fr); gap:24px;
}
.field-tag .item{font-size:12.5px; color:var(--moss-700);}
.field-tag .item b{display:block; color:var(--canopy-950); font-size:14.5px; margin-top:4px; letter-spacing:0.01em;}

.stat-band{background:var(--mist-100); color:var(--canopy-950); padding:20px 0; border-bottom:1px solid var(--line);}
.stat-band .wrap{display:flex; justify-content:space-between; flex-wrap:wrap; gap:14px; font-size:12.5px; letter-spacing:0.03em; color:var(--moss-700);}
.stat-band b{color:var(--clay-500); font-weight:600;}

section{padding:100px 0;}
.section-head{max-width:640px; margin-bottom:56px;}

.about{display:grid; grid-template-columns:1fr 1fr; gap:64px; align-items:center;}
.about-photo{ aspect-ratio:4/5; border-radius:3px; border:1px solid var(--line); position:relative; overflow:hidden; } .about-photo img{ width:100%; height:100%; display:block; object-fit:cover; /* Fills the container while keeping aspect ratio */ object-position:center; /* Keeps the image centered */ } .about-photo::after{ content:"Field photograph — canopy walkway, dawn"; position:absolute; bottom:16px; left:16px; right:16px; font-family:'IBM Plex Mono', monospace; font-size:11px; color:var(--moss-700); letter-spacing:0.02em; z-index:2; }
.about-body h2{font-size:clamp(26px,3vw,36px); margin-bottom:20px;}
.about-body p{font-size:16px; line-height:1.75; color:var(--canopy-900); opacity:0.85; margin-bottom:16px;}
.about-facts{margin-top:28px; display:grid; grid-template-columns:1fr 1fr; gap:18px; border-top:1px solid var(--line); padding-top:24px;}
.about-facts .f{font-size:12.5px; color:var(--moss-700);}
.about-facts .f b{display:block; font-family:'IBM Plex Mono',monospace; font-size:20px; color:var(--canopy-950); font-weight:600;}

.wildlife{background:var(--mist-100);}
.wgrid{display:grid; grid-template-columns:repeat(4,1fr); gap:1px; background:var(--line);}
.wcard{background:var(--mist-100); padding:28px 22px 24px;}
.wcard .photo{
  aspect-ratio:1/1;
  margin-bottom:18px;
  border-radius:3px;
  border:1px solid var(--line);
  overflow:hidden;
  position:relative;
}

.wcard .photo img{
  width:100%;
  height:100%;
  display:block;
  object-fit:cover;       /* Fill the container while maintaining aspect ratio */
  object-position:center; /* Keep the image centered */
}
.wcard h3{font-size:19px; color:var(--canopy-950); margin-bottom:4px;}
.wcard .latin{font-size:12px; font-style:italic; color:var(--clay-500); margin-bottom:12px; display:block;}
.wcard p{font-size:13.5px; line-height:1.55; color:var(--moss-700);}
.wcard .tag{margin-top:14px; font-size:11px; letter-spacing:0.03em; color:var(--moss-500); border-top:1px solid var(--line); padding-top:10px;}

.stay-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:24px;}
.scard{border:1px solid var(--line); border-radius:3px; padding:32px 26px; display:flex; flex-direction:column; gap:16px;}
.scard.featured{border-color:var(--clay-500); border-width:2px;}
.scard .kicker{font-size:11.5px; letter-spacing:0.08em; text-transform:uppercase; color:var(--clay-500); font-weight:600;}
.scard h3{font-size:22px;}
.scard .price{font-family:'IBM Plex Mono',monospace; font-size:15px; color:var(--moss-700);}
.scard p{font-size:14.5px; line-height:1.6; color:var(--moss-700); flex-grow:1;}
.scard .cta{font-size:13.5px; font-weight:600; padding-top:14px; border-top:1px solid var(--line); display:flex; align-items:center; gap:6px; color:var(--clay-500);}

.route{background:var(--mist-100); border:1px solid var(--line); padding:44px 40px; border-radius:3px; display:flex; align-items:center; justify-content:space-between; gap:12px; flex-wrap:wrap;}
.route .stop{text-align:center; flex:1; min-width:130px;}
.route .stop .dot{width:11px; height:11px; border-radius:50%; background:var(--clay-500); margin:0 auto 12px;}
.route .stop b{display:block; font-family:'Fraunces',serif; font-size:17px; margin-bottom:4px;}
.route .stop span{font-size:12px; color:var(--moss-700); font-family:'IBM Plex Mono',monospace;}
.route .arrow{flex:0 0 auto; font-family:'IBM Plex Mono',monospace; font-size:11.5px; color:var(--moss-700); text-align:center; padding-top:24px;}

.guides-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:28px;}
.gcard{border-top:2px solid var(--canopy-950); padding-top:18px;}
.gcard .photo{
  aspect-ratio:16/10;
  margin-bottom:18px;
  border-radius:3px;
  border:1px solid var(--line);
  overflow:hidden;
  position:relative;
}

.gcard .photo img{
  width:100%;
  height:100%;
  display:block;
  object-fit:cover;       /* Fill the container while maintaining aspect ratio */
  object-position:center; /* Keep the image centered */
}
.gcard .cat{font-size:11.5px; letter-spacing:0.06em; text-transform:uppercase; color:var(--clay-500); font-weight:600;}
.gcard h3{font-size:19px; margin:8px 0 8px; line-height:1.25;}
.gcard p{font-size:14px; color:var(--moss-700); line-height:1.6;}

@media (max-width:900px){
  .about, .stay-grid, .guides-grid{grid-template-columns:1fr;}
  .wgrid{grid-template-columns:repeat(2,1fr);}
  .field-tag{grid-template-columns:repeat(2,1fr);}
  .route{flex-direction:column;}
  .route .arrow{padding-top:0;}
}

/* ==========================================================================
   Enquiry form
   ========================================================================== */

.form-card{
  border:1px solid var(--line); border-radius:3px; padding:40px;
  background:var(--bg);
}
.form-row{display:grid; grid-template-columns:1fr 1fr; gap:20px;}
@media (max-width:640px){ .form-row{grid-template-columns:1fr;} }
.form-group{margin-bottom:22px;}
.form-group label{
  display:block; font-size:13px; font-weight:600; margin-bottom:8px;
  color:var(--canopy-950); letter-spacing:0.01em;
}
.form-group .hint{font-size:12px; color:var(--moss-500); font-weight:400; margin-left:4px;}
.form-group input,
.form-group select,
.form-group textarea{
  width:100%; padding:12px 14px; font-size:15px; font-family:'Public Sans', sans-serif;
  border:1px solid var(--line); border-radius:2px; background:#fff; color:var(--canopy-950);
}
.form-group input:focus,
.form-group select:focus,
.form-group textarea:focus{
  outline:none; border-color:var(--clay-500);
}
.form-group textarea{resize:vertical; min-height:110px;}
.form-submit{
  border:none; cursor:pointer; font-family:'Public Sans', sans-serif;
  width:100%;
}
.form-submit:disabled{opacity:0.6; cursor:not-allowed;}
.form-status{
  margin-top:16px; padding:14px 16px; border-radius:2px; font-size:14px; display:none;
}
.form-status.success{display:block; background:#EAF1E4; color:var(--canopy-900); border:1px solid var(--line);}
.form-status.error{display:block; background:#F7E9E2; color:var(--clay-600); border:1px solid var(--clay-500);}
.form-note{font-size:12.5px; color:var(--moss-500); margin-top:14px; line-height:1.5;}
