/* =====================================================================
   Eastern Stirling Range — shared stylesheet
   Palette: eucalypt green / granite / mist, with an ochre earth accent.
   Fonts: Fraunces (display), Spectral (body) — loaded per page via <link>.
   ===================================================================== */
:root{
  --paper:#f4f1ea; --paper-2:#ece7dc; --ink:#22281d; --ink-soft:#3c4434;
  --eucalypt:#3c5a39; --eucalypt-deep:#28401f; --granite:#73776c;
  --mist:#c9d2cd; --deep:#56686a; --ochre:#a3702f; --ochre-soft:#b98a4d;
  --warn:#9d3b2f; --warn-bg:#f3e0db; --line:#d8d2c4;
  --shadow:0 1px 2px rgba(34,40,29,.06),0 8px 30px rgba(34,40,29,.08);
}
*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  margin:0;background:var(--paper);color:var(--ink);
  font-family:"Spectral",Georgia,serif;font-weight:400;font-size:18px;line-height:1.72;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
}
img{max-width:100%;height:auto;display:block;}
a{color:var(--eucalypt);text-decoration:underline;text-underline-offset:3px;text-decoration-thickness:1px;text-decoration-color:var(--ochre-soft);}
a:hover{color:var(--ochre);}
strong{font-weight:500;color:var(--ink);}
em.term{font-style:italic;color:var(--eucalypt-deep);font-weight:500;}

/* ---------- Top navigation ---------- */
.nav{
  position:sticky;top:0;z-index:50;
  background:rgba(244,241,234,.92);backdrop-filter:blur(8px);
  border-bottom:1px solid var(--line);
}
.nav-inner{max-width:1000px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;
  gap:16px;padding:12px 24px;flex-wrap:wrap;}
.nav-brand{font-family:"Fraunces",serif;font-weight:600;font-size:1.05rem;color:var(--eucalypt-deep);
  text-decoration:none;letter-spacing:-.01em;white-space:nowrap;}
.nav-links{display:flex;gap:4px 18px;flex-wrap:wrap;align-items:center;}
.nav-links a{font-family:"Spectral",serif;font-size:.96rem;color:var(--ink-soft);text-decoration:none;padding:4px 2px;border-bottom:2px solid transparent;}
.nav-links a:hover{color:var(--ochre);}
.nav-links a[aria-current="page"]{color:var(--eucalypt-deep);border-bottom-color:var(--ochre);}

/* ---------- Hero with photographic background ---------- */
.hero{position:relative;min-height:62vh;display:flex;align-items:flex-end;
  background-size:cover;background-position:center;overflow:hidden;}
.hero::before{content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(20,30,18,.18) 0%,rgba(20,30,18,.06) 38%,rgba(20,30,18,.62) 100%);}
.hero--ridge{background-image:url("images/bg-ridge.jpg");}
.hero--cliffs{background-image:url("images/bg-cliffs.jpg");}
.hero--flowers{background-image:url("images/bg-flowers.jpg");}
.hero-content{position:relative;z-index:1;max-width:1000px;margin:0 auto;width:100%;padding:0 24px 46px;}
.hero .eyebrow{font-style:italic;color:#eef1e8;font-size:1.02rem;margin:0 0 10px;text-shadow:0 1px 6px rgba(0,0,0,.4);}
.hero h1{font-family:"Fraunces",serif;font-weight:500;color:#fff;margin:0;line-height:1.03;letter-spacing:-.01em;
  font-size:clamp(2.3rem,6vw,4rem);text-shadow:0 2px 16px rgba(0,0,0,.45);}
.hero .tagline{display:block;font-style:italic;font-weight:400;color:#eef1e8;font-size:.4em;margin-top:.5em;text-shadow:0 1px 8px rgba(0,0,0,.4);}

/* compact hero for the appendix (no photo) */
.hero-mist{background:linear-gradient(180deg,#dfe5e1,#d4dcd6 55%,var(--paper));padding:60px 24px 30px;}
.hero-mist .wrap{max-width:760px;margin:0 auto;}

/* ---------- Page layout ---------- */
main{max-width:760px;margin:0 auto;padding:0 24px 40px;}
.intro{margin-top:38px;}
.lead{font-size:1.2rem;color:var(--ink-soft);}
p{margin:0 0 1.05em;}
section{margin-top:40px;scroll-margin-top:84px;}
h2{font-family:"Fraunces",serif;font-weight:500;font-size:1.6rem;color:var(--eucalypt-deep);letter-spacing:-.01em;margin:0 0 .5em;line-height:1.15;}
h3{font-family:"Fraunces",serif;font-weight:500;font-size:1.32rem;color:var(--eucalypt-deep);letter-spacing:-.01em;margin:0 0 .35em;line-height:1.18;}
h3 .num{font-size:.8rem;font-style:italic;color:var(--ochre);display:inline-block;margin-right:.55em;vertical-align:.18em;font-family:"Spectral",serif;}

/* ---------- Route segments ---------- */
.segment{padding:22px 0;border-bottom:1px solid var(--line);}
.segment:last-of-type{border-bottom:none;}
.seg-head{display:flex;align-items:baseline;flex-wrap:wrap;gap:10px 14px;margin-bottom:.3em;}
.seg-head h3{margin:0;}
.badge{display:inline-block;font-family:"Spectral",serif;font-size:.74rem;letter-spacing:.07em;text-transform:uppercase;
  padding:3px 11px;border-radius:999px;background:#dde7d8;color:#33502c;white-space:nowrap;}
.code{font-family:"Spectral",serif;font-style:italic;color:var(--granite);font-size:.96rem;}

/* ---------- Cards (home page nav) ---------- */
.cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px;margin-top:18px;}
.card{display:block;text-decoration:none;color:inherit;background:var(--paper-2);border:1px solid var(--line);
  border-left:3px solid var(--ochre);border-radius:4px;padding:20px 22px;transition:transform .2s,box-shadow .2s;}
.card:hover{transform:translateY(-2px);box-shadow:var(--shadow);color:inherit;}
.card h3{margin:0 0 .25em;}
.card p{margin:0;font-size:.98rem;color:var(--ink-soft);}

/* ---------- Place-codes key ---------- */
.codes{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:6px 18px;margin:14px 0 0;
  font-size:.95rem;color:var(--ink-soft);}
.codes b{color:var(--eucalypt-deep);font-weight:600;font-family:"Spectral",serif;}

/* ---------- Figures: maps & photos ---------- */
figure{margin:24px 0;}
figure img{border-radius:4px;box-shadow:var(--shadow);background:#fff;}
figcaption{font-size:.92rem;color:var(--granite);font-style:italic;margin-top:8px;line-height:1.5;}
.map figure img{border:1px solid var(--line);}

/* photo galleries — invisible until photos are added; masonry-style columns */
.gallery{column-width:240px;column-gap:14px;margin:22px 0 6px;}
.gallery:empty{display:none;}
figure.ph{break-inside:avoid;-webkit-column-break-inside:avoid;margin:0 0 14px;display:inline-block;width:100%;}
figure.ph img{width:100%;height:auto;border-radius:4px;box-shadow:var(--shadow);background:#fff;}
figure.ph a{display:block;line-height:0;}
figure.ph figcaption{margin-top:6px;line-height:1.45;}
/* a single centred feature photo (e.g. the closing image) */
figure.ph-feature{max-width:780px;margin:38px auto 0;}
figure.ph-feature a{display:block;line-height:0;}
figure.ph-feature img{width:100%;height:auto;border-radius:4px;box-shadow:var(--shadow);}
figure.ph-feature figcaption{margin-top:12px;text-align:center;font-style:italic;color:var(--granite);line-height:1.5;}

/* ---------- Callouts ---------- */
.callout{margin:22px 0;background:var(--paper-2);border:1px solid var(--line);border-left:3px solid var(--ochre);
  border-radius:3px;padding:18px 22px;}
.callout h3{margin-top:0;}
.callout p{margin:0;}
.callout--warn{background:var(--warn-bg);border-color:#e3c4bc;border-left-color:var(--warn);}
.callout--warn .label{display:block;font-family:"Spectral",serif;font-weight:600;letter-spacing:.04em;
  text-transform:uppercase;font-size:.78rem;color:var(--warn);margin-bottom:6px;}

/* ---------- Appendix-specific (names & country) ---------- */
.kicker{font-family:"Spectral",serif;font-style:italic;letter-spacing:.14em;text-transform:uppercase;font-size:.78rem;color:var(--ochre);margin:0 0 12px;}
.appendix-title{font-family:"Fraunces",serif;font-weight:500;font-size:clamp(2rem,5vw,2.9rem);line-height:1.06;letter-spacing:-.01em;color:var(--eucalypt-deep);margin:0;}
.appendix-sub{font-style:italic;color:var(--ink-soft);font-size:1.1rem;margin:.5em 0 0;}
.names{margin-top:24px;border-top:1px solid var(--line);}
.name-row{padding:20px 0;border-bottom:1px solid var(--line);}
.name-head{display:flex;align-items:baseline;flex-wrap:wrap;gap:10px;}
.name-noongar{font-family:"Fraunces",serif;font-weight:600;font-size:1.26rem;color:var(--eucalypt-deep);letter-spacing:-.01em;}
.name-english{font-style:italic;color:var(--granite);font-size:1rem;}
.name-note{margin:4px 0 0;color:var(--ink-soft);font-size:1.02rem;}
.tag{display:inline-block;font-family:"Spectral",serif;font-size:.7rem;letter-spacing:.09em;text-transform:uppercase;padding:3px 9px;border-radius:999px;white-space:nowrap;vertical-align:1px;}
.tag.doc{background:#dde7d8;color:#33502c;}
.tag.partial{background:#efe2cb;color:#7e5a23;}
.tag.coined{background:#e3dbe8;color:#5b4a6b;}
.tag.unknown{background:#e4e2dc;color:#5f5b50;}
.legend{display:flex;flex-wrap:wrap;gap:10px 18px;margin:16px 0 0;font-size:.92rem;color:var(--granite);}
.legend span{display:inline-flex;align-items:center;gap:7px;}
.legend .dot{width:10px;height:10px;border-radius:50%;}
.dot.doc{background:#7ba06f;}.dot.partial{background:#c79a52;}.dot.coined{background:#9a85ad;}.dot.unknown{background:#b3aea0;}
.corrections,.nomen{margin-top:40px;background:var(--paper-2);border:1px solid var(--line);border-left:3px solid var(--ochre);border-radius:3px;padding:26px 30px;}
.corrections h2,.nomen h2{font-size:1.3rem;margin-top:0;}
.sources{margin-top:44px;font-size:.95rem;color:var(--granite);}
.sources h2{font-size:1.1rem;color:var(--ink-soft);}
.sources ul{margin:0;padding-left:1.2em;}
.sources li{margin:0 0 .45em;}
.backtop{display:inline-block;margin-top:34px;font-style:italic;font-size:.95rem;color:var(--deep);text-decoration:none;}
.backtop:hover{color:var(--ochre);}

/* ---------- Footer ---------- */
footer{border-top:1px solid var(--line);background:var(--paper-2);}
.foot-inner{max-width:760px;margin:0 auto;padding:30px 24px 60px;font-size:.92rem;color:var(--granite);font-style:italic;}
.foot-inner a{color:var(--deep);}

/* ---------- reveal ---------- */
.reveal{opacity:0;transform:translateY(12px);animation:rise .8s cubic-bezier(.2,.7,.2,1) forwards;}
@keyframes rise{to{opacity:1;transform:none;}}
@media (prefers-reduced-motion:reduce){.reveal{animation:none;opacity:1;transform:none;}}

@media (max-width:560px){
  body{font-size:17px;}
  .hero{min-height:54vh;}
  main{padding:0 20px 32px;}
  .corrections,.nomen{padding:22px 20px;}
}
