/* Exploration page styles — minimal, complementary to base.css */
:root {
  --shade-ink: #0f1714;
  --shade-forest: #0e2a24;
  --shade-ash: #1e2523;
  --accent: #7cc8a4;
}

.exploration-hero { position: relative; background: linear-gradient(180deg, rgba(10,14,12,.7), rgba(10,14,12,.9)); color: #e7efe9; overflow: clip; }
.exploration-hero__media { position: absolute; inset: 0; background: url('/assets/images/hero-mist-forest.webp') center/cover no-repeat; filter: brightness(.6) contrast(1.05); }
.exploration-hero__content { position: relative; padding: clamp(3rem, 5vw, 6rem) 0; }
.exploration-hero .eyebrow { letter-spacing: .08em; text-transform: uppercase; color: #a9dac2; opacity: .9; }
.exploration-hero .lead { max-width: 56ch; opacity: .95; }

.inpage-nav ul { display: flex; gap: .75rem; flex-wrap: wrap; margin-top: 1rem; }
.inpage-nav a { display: inline-block; padding: .5rem .75rem; border: 1px solid rgba(255,255,255,.2); border-radius: .5rem; color: #e7efe9; text-decoration: none; backdrop-filter: blur(2px); }
.inpage-nav a:is(:hover,:focus-visible) { border-color: var(--accent); color: #fff; }

.section { padding: clamp(2rem, 5vw, 4rem) 0; background: var(--shade-ink); color: #dfe9e3; }
.section--alt { background: var(--shade-ash); }
.section__header h2 { margin-bottom: .5rem; }
.section__body { margin-top: 1rem; }

.container { width: min(1100px, 92%); margin-inline: auto; }

.grid-2 { display: grid; grid-template-columns: 1fr; gap: 1.25rem; }
.grid-3 { display: grid; grid-template-columns: 1fr; gap: 1.25rem; }
@media (min-width: 768px) {
  .grid-2 { grid-template-columns: 1fr 1fr; gap: 1.5rem; }
  .grid-3 { grid-template-columns: repeat(3, 1fr); gap: 1.5rem; }
}

.bullet { list-style: none; padding: 0; }
.bullet li { position: relative; padding-left: 1.25rem; margin: .5rem 0; }
.bullet li::before { content: ""; position: absolute; left: 0; top: .6em; width: .5rem; height: .5rem; border-radius: 50%; background: var(--accent); box-shadow: 0 0 0 2px rgba(124,200,164,.2); }

.figure { margin: 0; }
.figure img { width: 100%; height: auto; border-radius: .5rem; }
.figure figcaption { font-size: .9rem; opacity: .85; margin-top: .5rem; }
.figure--wide img { aspect-ratio: 16/9; object-fit: cover; }

.card { background: linear-gradient(180deg, rgba(20,30,26,.6), rgba(20,30,26,.9)); border: 1px solid rgba(124,200,164,.15); padding: 1rem; border-radius: .75rem; }
.card h3 { margin-top: 0; }

.quotes .quote { margin: 0; padding: 1rem; background: rgba(10,14,12,.5); border-left: 3px solid var(--accent); border-radius: .25rem; }
.quotes cite { display: block; margin-top: .5rem; opacity: .8; font-style: normal; }

.steps { counter-reset: step; list-style: none; padding: 0; }
.steps li { counter-increment: step; margin: .5rem 0; padding-left: 2rem; position: relative; }
.steps li::before { content: counter(step); position: absolute; left: 0; top: 0; width: 1.4rem; height: 1.4rem; display: grid; place-items: center; border-radius: 999px; background: var(--accent); color: #0b1411; font-weight: 700; }

.accordion { border: 1px solid rgba(124,200,164,.2); border-radius: .5rem; padding: .5rem .75rem; background: rgba(14,42,36,.25); }
.accordion + .accordion { margin-top: .5rem; }
.accordion__summary { cursor: pointer; font-weight: 600; }
.accordion[open] { background: rgba(14,42,36,.35); }

.timeline { list-style: none; padding: 0; display: grid; gap: .5rem; }
.timeline li { background: rgba(10,14,12,.4); padding: .75rem; border-radius: .5rem; border: 1px dashed rgba(124,200,164,.2); }

.cta-group { display: flex; gap: .75rem; flex-wrap: wrap; }
.button { appearance: none; border: 1px solid var(--accent); background: var(--accent); color: #0b1411; padding: .6rem 1rem; border-radius: .5rem; text-decoration: none; font-weight: 600; }
.button--ghost { background: transparent; color: #cfe7da; border-color: rgba(124,200,164,.6); }
.button:is(:hover,:focus-visible) { filter: brightness(1.05); }

.section--cta { background: linear-gradient(180deg, var(--shade-ash), var(--shade-ink)); border-top: 1px solid rgba(124,200,164,.15); border-bottom: 1px solid rgba(124,200,164,.15); }
.cta-row { display: flex; align-items: center; justify-content: space-between; gap: 1rem; flex-wrap: wrap; }

.visually-hidden { position: absolute !important; clip: rect(1px, 1px, 1px, 1px); clip-path: inset(50%); height: 1px; width: 1px; overflow: hidden; white-space: nowrap; }
