/* ===========================================================
   WIRA BALI TOUR — Design tokens
   Palette   : hutan gelap #142019, panel #1D2B22, emas sawah #C99A3D,
               terracotta lempung #B5563A, krem kertas #F1ECDE
   Type      : Fraunces (display) / Inter (body) / IBM Plex Mono (data)
   Signature : "garis rute perjalanan" — motif kontur penghubung ikon
   =========================================================== */

:root{
  --bg-deep:#142019;
  --bg-panel:#1d2b22;
  --bg-panel-2:#233327;
  --gold:#c99a3d;
  --clay:#b5563a;
  --paper:#f1ecde;
  --paper-dim:#c9c3af;
  --line:#33473a;
  --muted:#9fae9f;
  --radius:2px;
  --maxw:1180px;
}

*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  margin:0;
  background:var(--bg-deep);
  color:var(--paper);
  font-family:'Inter',system-ui,sans-serif;
  font-size:16px;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
}

h1,h2,h3,.display{
  font-family:'Fraunces',serif;
  font-weight:600;
  letter-spacing:-0.01em;
  color:var(--paper);
  margin:0 0 .4em;
}
h1{font-size:clamp(2.4rem,5vw,4rem); line-height:1.05;}
h2{font-size:clamp(1.7rem,3vw,2.4rem); line-height:1.15;}
h3{font-size:1.3rem;}
p{color:var(--paper-dim); margin:0 0 1em;}
a{color:inherit; text-decoration:none;}
.eyebrow{
  font-family:'IBM Plex Mono',monospace;
  font-size:.75rem;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:var(--gold);
  display:inline-flex;
  align-items:center;
  gap:.5em;
}
.eyebrow::before{content:"";width:18px;height:1px;background:var(--gold);display:inline-block;}

.wrap{max-width:var(--maxw); margin:0 auto; padding:0 28px;}
img{max-width:100%; display:block;}

/* ---------- header ---------- */
header.site{
  position:sticky; top:0; z-index:40;
  background:rgba(20,32,25,.92);
  backdrop-filter:blur(6px);
  border-bottom:1px solid var(--line);
}
.nav{display:flex; align-items:center; justify-content:space-between; padding:16px 0;}
.logo{font-family:'Fraunces',serif; font-weight:600; font-size:1.25rem; color:var(--paper);}
.logo span{color:var(--gold);}
.navlinks{display:flex; gap:28px; font-size:.92rem;}
.navlinks a{color:var(--paper-dim); transition:color .15s;}
.navlinks a:hover, .navlinks a.active{color:var(--gold);}
.btn{
  display:inline-flex; align-items:center; gap:.5em;
  padding:.75em 1.4em;
  background:var(--gold);
  color:var(--bg-deep);
  font-weight:600;
  font-size:.9rem;
  border-radius:var(--radius);
  border:none;
  cursor:pointer;
}
.btn.outline{
  background:transparent;
  border:1px solid var(--gold);
  color:var(--gold);
}
.btn.clay{background:var(--clay); color:var(--paper);}

/* ---------- hero ---------- */
.hero{
  padding:96px 0 72px;
  position:relative;
  overflow:hidden;
  border-bottom:1px solid var(--line);
}
.hero-grid{display:grid; grid-template-columns:1.1fr .9fr; gap:56px; align-items:center;}
@media(max-width:900px){.hero-grid{grid-template-columns:1fr;}}
.hero p.lead{font-size:1.15rem; max-width:46ch;}
.hero-actions{display:flex; gap:14px; margin-top:28px; flex-wrap:wrap;}

/* itinerary line signature — svg route with numbered stops */
.route-svg{width:100%; height:auto;}
.route-svg .path{fill:none; stroke:var(--gold); stroke-width:2; stroke-dasharray:6 6;}
.route-svg .stop{fill:var(--bg-deep); stroke:var(--gold); stroke-width:2;}
.route-svg .stop-label{font-family:'IBM Plex Mono',monospace; font-size:11px; fill:var(--paper-dim);}
.route-svg .stop-day{font-family:'IBM Plex Mono',monospace; font-size:13px; fill:var(--gold); font-weight:600;}

/* ---------- sections ---------- */
section{padding:80px 0;}
section.alt{background:var(--bg-panel); border-top:1px solid var(--line); border-bottom:1px solid var(--line);}
.section-head{max-width:640px; margin-bottom:48px;}

/* card grid */
.grid3{display:grid; grid-template-columns:repeat(3,1fr); gap:24px;}
.grid2{display:grid; grid-template-columns:repeat(2,1fr); gap:24px;}
@media(max-width:860px){.grid3,.grid2{grid-template-columns:1fr;}}

.card{
  background:var(--bg-panel-2);
  border:1px solid var(--line);
  border-radius:var(--radius);
  overflow:hidden;
  display:flex; flex-direction:column;
}
.card img{aspect-ratio:4/3; object-fit:cover; width:100%;}
.card .body{padding:22px;}
.card .meta{
  font-family:'IBM Plex Mono',monospace;
  font-size:.75rem; color:var(--gold);
  display:flex; gap:14px; margin-bottom:10px; text-transform:uppercase; letter-spacing:.06em;
}
.price{font-family:'Fraunces',serif; color:var(--gold); font-size:1.4rem; margin-top:8px;}
.price small{font-family:'Inter',sans-serif; color:var(--muted); font-size:.75rem; font-weight:400;}

/* day-by-day itinerary block (used on detail pages) */
.day-block{
  display:grid; grid-template-columns:110px 1fr; gap:24px;
  padding:28px 0; border-top:1px solid var(--line);
}
.day-block:first-of-type{border-top:none;}
.day-num{font-family:'Fraunces',serif; font-size:2rem; color:var(--gold);}
.day-num small{display:block; font-family:'IBM Plex Mono',monospace; font-size:.7rem; color:var(--muted); text-transform:uppercase;}

/* testimonial */
.testi{
  background:var(--bg-panel-2); border:1px solid var(--line); border-radius:var(--radius);
  padding:24px;
}
.testi .stars{color:var(--gold); letter-spacing:2px; margin-bottom:10px;}
.testi .who{font-family:'IBM Plex Mono',monospace; font-size:.8rem; color:var(--muted); margin-top:14px;}

/* faq */
.faq-item{border-top:1px solid var(--line); padding:20px 0;}
.faq-item summary{cursor:pointer; font-family:'Fraunces',serif; font-size:1.1rem; color:var(--paper);}
.faq-item p{margin-top:12px;}

/* contact form */
.field{margin-bottom:16px;}
.field label{display:block; font-size:.82rem; color:var(--muted); margin-bottom:6px; font-family:'IBM Plex Mono',monospace; text-transform:uppercase; letter-spacing:.05em;}
.field input, .field select, .field textarea{
  width:100%; padding:.8em .9em; background:var(--bg-deep); border:1px solid var(--line);
  color:var(--paper); border-radius:var(--radius); font-family:'Inter',sans-serif; font-size:.95rem;
}
.field textarea{min-height:120px; resize:vertical;}

/* footer */
footer.site{background:var(--bg-panel); border-top:1px solid var(--line); padding:56px 0 28px;}
.foot-grid{display:grid; grid-template-columns:1.3fr .8fr .8fr .9fr; gap:32px;}
@media(max-width:860px){.foot-grid{grid-template-columns:1fr 1fr;}}
.foot-grid h4{font-family:'IBM Plex Mono',monospace; font-size:.8rem; text-transform:uppercase; letter-spacing:.08em; color:var(--gold); margin-bottom:14px;}
.foot-grid a{display:block; color:var(--paper-dim); font-size:.9rem; margin-bottom:8px;}
.foot-bottom{margin-top:40px; padding-top:20px; border-top:1px solid var(--line); font-size:.8rem; color:var(--muted); display:flex; justify-content:space-between; flex-wrap:wrap; gap:10px;}

/* breadcrumb */
.crumbs{font-family:'IBM Plex Mono',monospace; font-size:.75rem; color:var(--muted); padding:18px 0 0;}
.crumbs a{color:var(--muted);} .crumbs a:hover{color:var(--gold);}
.crumbs .sep{margin:0 8px; opacity:.5;}

/* tag pill */
.pill{display:inline-block; padding:.3em .8em; border:1px solid var(--line); border-radius:20px; font-size:.75rem; color:var(--muted); margin:0 6px 6px 0; font-family:'IBM Plex Mono',monospace;}
