
:root{
  --bg:#faf5ec;
  --ink:#1d1a16;
  --ink-soft:#4a443c;
  --paper:#fffaf0;
  --terra:#c9522a;
  --terra-deep:#8f3416;
  --sun:#e8a93a;
  --olive:#5e6e3e;
  --sea:#1f6f8b;
  --line:#e6dcc8;
  --shadow:0 20px 60px -30px rgba(143,52,22,.35);
  --radius:18px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:'Inter','Helvetica Neue',sans-serif;
  background:var(--bg);
  color:var(--ink);
  line-height:1.65;
  font-size:17px;
  -webkit-font-smoothing:antialiased;
}
.serif{font-family:'Fraunces','Playfair Display',Georgia,serif;font-weight:600;letter-spacing:-.01em}
h1,h2,h3{font-family:'Fraunces',Georgia,serif;font-weight:600;line-height:1.1;letter-spacing:-.02em;color:var(--ink)}
h1{font-size:clamp(2.6rem,6vw,5rem)}
h2{font-size:clamp(1.8rem,3.4vw,2.8rem);margin-bottom:.6em}
h3{font-size:1.35rem;margin-bottom:.4em}
p{margin-bottom:1em;color:var(--ink-soft)}
a{color:var(--terra);text-decoration:none}
a:hover{color:var(--terra-deep)}
img{max-width:100%;display:block}

/* ─── Layout ─── */
.wrap{max-width:1180px;margin:0 auto;padding:0 28px}
.narrow{max-width:780px;margin:0 auto;padding:0 28px}

/* ─── Nav ─── */
.nav{
  position:sticky;top:0;z-index:50;
  background:rgba(250,245,236,.92);
  backdrop-filter:blur(14px);
  border-bottom:1px solid var(--line);
}
.nav-inner{
  display:flex;align-items:center;justify-content:space-between;
  padding:14px 28px;max-width:1280px;margin:0 auto;
}
.brand{
  font-family:'Fraunces',serif;font-weight:700;font-size:1.3rem;
  color:var(--ink);display:flex;align-items:center;gap:8px;
}
.brand-dot{width:10px;height:10px;background:var(--terra);border-radius:50%}
.nav-links{display:flex;gap:22px;flex-wrap:wrap;font-size:.92rem}
.nav-links a{color:var(--ink-soft);font-weight:500}
.nav-links a:hover,.nav-links a.active{color:var(--terra)}
@media(max-width:780px){.nav-links{display:none}}

/* ─── Hero ─── */
.hero{
  position:relative;overflow:hidden;
  padding:90px 0 80px;
}
.hero-grid{
  display:grid;grid-template-columns:1.1fr .9fr;gap:60px;align-items:center;
}
@media(max-width:880px){.hero-grid{grid-template-columns:1fr;gap:40px}}
.eyebrow{
  display:inline-flex;align-items:center;gap:8px;
  font-size:.78rem;letter-spacing:.18em;text-transform:uppercase;
  color:var(--terra);font-weight:600;margin-bottom:20px;
}
.eyebrow::before{content:"";width:28px;height:1.5px;background:var(--terra)}
.hero h1{margin-bottom:20px}
.hero-lead{font-size:1.2rem;color:var(--ink-soft);max-width:540px}
.hero-img{
  border-radius:var(--radius);overflow:hidden;
  box-shadow:var(--shadow);
  aspect-ratio:4/5;
  background:#e8d9b8;
}
.hero-img img{width:100%;height:100%;object-fit:cover}

/* ─── Sections ─── */
section{padding:70px 0}
.section-soft{background:var(--paper);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.lead{font-size:1.18rem;color:var(--ink-soft);margin-bottom:2em}

/* ─── Cards ─── */
.grid{display:grid;gap:24px}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-2{grid-template-columns:repeat(2,1fr)}
@media(max-width:880px){.grid-3,.grid-2{grid-template-columns:1fr}}
.card{
  background:var(--paper);border:1px solid var(--line);
  border-radius:var(--radius);padding:28px;
  transition:transform .3s ease, box-shadow .3s ease;
}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.card .num{
  font-family:'Fraunces',serif;font-size:2.2rem;color:var(--terra);
  font-weight:600;line-height:1;margin-bottom:14px;display:block;
}
.card .icon{font-size:2rem;margin-bottom:12px;display:block}

/* ─── Page cards (home) ─── */
.page-card{
  display:flex;flex-direction:column;
  background:var(--paper);border:1px solid var(--line);
  border-radius:var(--radius);overflow:hidden;text-decoration:none;color:inherit;
  transition:transform .3s ease, box-shadow .3s ease;
}
.page-card:hover{transform:translateY(-6px);box-shadow:var(--shadow);color:inherit}
.page-card .thumb{
  aspect-ratio:4/3;background:#e8d9b8;position:relative;overflow:hidden;
}
.page-card .thumb img{width:100%;height:100%;object-fit:cover;transition:transform .6s ease}
.page-card:hover .thumb img{transform:scale(1.05)}
.page-card .body{padding:22px}
.page-card h3{margin-bottom:8px}
.page-card .meta{font-size:.78rem;letter-spacing:.15em;text-transform:uppercase;color:var(--terra);font-weight:600}
.page-card p{font-size:.95rem;margin:8px 0 0}

/* ─── Tip box ─── */
.tip{
  border-left:4px solid var(--sun);
  background:linear-gradient(180deg,rgba(232,169,58,.08),transparent);
  padding:22px 26px;border-radius:0 var(--radius) var(--radius) 0;
  margin:28px 0;
}
.tip .label{
  font-size:.75rem;letter-spacing:.2em;text-transform:uppercase;
  color:var(--sun);font-weight:700;margin-bottom:6px;
}

/* ─── Route graphic ─── */
.route{
  display:flex;align-items:flex-start;gap:0;
  margin:40px 0;padding:30px 0;
  overflow-x:auto;
}
.stop{flex:1;min-width:160px;text-align:center;position:relative;padding:0 10px}
.stop:not(:last-child)::after{
  content:"";position:absolute;top:18px;left:60%;right:-40%;
  height:2px;background:repeating-linear-gradient(90deg,var(--terra) 0 8px,transparent 8px 14px);
}
.stop .dot{
  width:36px;height:36px;border-radius:50%;
  background:var(--terra);color:#fff;
  display:flex;align-items:center;justify-content:center;
  margin:0 auto 14px;font-weight:700;font-family:'Fraunces',serif;
  border:4px solid var(--bg);box-shadow:0 0 0 2px var(--terra);
  position:relative;z-index:2;
}
.stop h4{font-family:'Fraunces',serif;font-size:1rem;margin-bottom:4px;color:var(--ink)}
.stop p{font-size:.85rem;margin:0}

/* ─── Stats ─── */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin:40px 0}
@media(max-width:780px){.stats{grid-template-columns:repeat(2,1fr)}}
.stat{text-align:center;padding:24px 12px;background:var(--paper);border-radius:var(--radius);border:1px solid var(--line)}
.stat .big{font-family:'Fraunces',serif;font-size:2.4rem;color:var(--terra);font-weight:600;line-height:1}
.stat .lbl{font-size:.8rem;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-soft);margin-top:6px}

/* ─── Quote ─── */
.quote{
  font-family:'Fraunces',serif;font-style:italic;font-weight:500;
  font-size:clamp(1.4rem,2.4vw,2rem);line-height:1.35;
  color:var(--ink);text-align:center;
  max-width:760px;margin:40px auto;padding:0 20px;
  position:relative;
}
.quote::before,.quote::after{
  font-family:'Fraunces',serif;color:var(--terra);font-size:3rem;
  line-height:0;vertical-align:-.4em;
}
.quote::before{content:"“";margin-right:.1em}
.quote::after{content:"”";margin-left:.1em}
.quote-cite{display:block;margin-top:14px;font-style:normal;font-size:.85rem;letter-spacing:.15em;text-transform:uppercase;color:var(--ink-soft);font-family:'Inter',sans-serif;font-weight:600}

/* ─── Next page ─── */
.next-nav{
  display:flex;justify-content:space-between;align-items:center;
  padding:40px 0;border-top:1px solid var(--line);margin-top:60px;gap:20px;flex-wrap:wrap;
}
.next-nav a{
  display:inline-flex;flex-direction:column;gap:4px;
  padding:14px 22px;border-radius:var(--radius);
  background:var(--paper);border:1px solid var(--line);
  transition:all .25s ease;
}
.next-nav a:hover{background:var(--terra);color:#fff;border-color:var(--terra)}
.next-nav .meta{font-size:.72rem;letter-spacing:.15em;text-transform:uppercase;opacity:.65}
.next-nav .ttl{font-family:'Fraunces',serif;font-size:1.1rem;font-weight:600}

/* ─── Footer ─── */
footer{
  background:var(--ink);color:#bfb6a6;padding:60px 0 40px;margin-top:60px;
}
footer .wrap{display:grid;grid-template-columns:1.5fr 1fr 1fr;gap:40px}
@media(max-width:780px){footer .wrap{grid-template-columns:1fr}}
footer h4{font-family:'Fraunces',serif;color:#fff;font-size:1.1rem;margin-bottom:14px}
footer a{color:#bfb6a6;display:block;padding:4px 0;font-size:.92rem}
footer a:hover{color:var(--sun)}
footer .small{margin-top:30px;padding-top:20px;border-top:1px solid #2c2823;font-size:.82rem;text-align:center;color:#7a7468}

/* ─── Tag chips ─── */
.tags{display:flex;flex-wrap:wrap;gap:8px;margin:20px 0}
.tag{
  font-size:.78rem;padding:6px 14px;border-radius:999px;
  background:var(--paper);border:1px solid var(--line);color:var(--ink-soft);
  font-weight:500;
}
.tag.warm{background:rgba(201,82,42,.1);color:var(--terra-deep);border-color:rgba(201,82,42,.2)}
.tag.sea{background:rgba(31,111,139,.1);color:var(--sea);border-color:rgba(31,111,139,.2)}
.tag.olive{background:rgba(94,110,62,.1);color:var(--olive);border-color:rgba(94,110,62,.2)}

/* ─── Decorative SVG band ─── */
.wave{display:block;width:100%;height:60px;color:var(--paper)}
