@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,400;0,500;0,600;1,400;1,500&family=DM+Mono:wght@400;500&family=DM+Sans:wght@300;400;500&display=swap');

/* ── Design tokens ─────────────────────────────────────────────────────────── */
:root {
  --ink:          #1c2118;
  --ink-mid:      #3d4a36;
  --ink-soft:     #6b7a62;
  --paper:        #f7f4ed;
  --paper-warm:   #ede9df;
  --paper-deep:   #e4dfd2;
  --rule:         rgba(28,33,24,.12);
  --rule-strong:  rgba(28,33,24,.25);
  --green:        #2e4a1e;
  --green-mid:    #4a7035;
  --green-light:  #e8f0e2;
  --terracotta:   #8b3a1a;
  --gold:         #a07830;
  --gold-light:   #f5edd8;
  --mono:         'DM Mono', monospace;
  --sans:         'DM Sans', sans-serif;
  --serif:        'Cormorant Garamond', Georgia, serif;
}

/* ── Reset ─────────────────────────────────────────────────────────────────── */
*,*::before,*::after { box-sizing: border-box; margin: 0; padding: 0; }
html { font-size: 16px; scroll-behavior: smooth; }
body { background: var(--paper); color: var(--ink); font-family: var(--sans); font-weight: 300; line-height: 1.65; }
a { color: var(--green); text-decoration: none; }
a:hover { color: var(--terracotta); }

/* ── Layout ────────────────────────────────────────────────────────────────── */
.page-wrap { max-width: 1080px; margin: 0 auto; padding: 0 2rem; }

/* ── Top bar ───────────────────────────────────────────────────────────────── */
.top-bar { border-bottom: 1px solid var(--rule); padding: .7rem 0; }
.top-bar-shell { display: flex; justify-content: space-between; align-items: center; gap: 1rem; flex-wrap: wrap; }
.top-bar-id { font-family: var(--mono); font-size: .68rem; letter-spacing: .1em; text-transform: uppercase; color: var(--ink-soft); display: flex; align-items: center; gap: .75rem; }
.top-bar-logo { height: 28px; width: auto; display: block; }
.top-bar-links { display: flex; gap: 1.5rem; flex-wrap: wrap; }
.top-bar-links a { font-family: var(--mono); font-size: .68rem; letter-spacing: .08em; text-transform: uppercase; color: var(--ink-soft); }
.top-bar-links a:hover { color: var(--green); }

/* ── Pilot banner ──────────────────────────────────────────────────────────── */
.pilot-banner { background: var(--gold-light); border-bottom: 1px solid rgba(160,120,48,.3); padding: .5rem 0; }
.pilot-banner-inner { font-family: var(--mono); font-size: .65rem; letter-spacing: .06em; color: var(--gold); display: flex; align-items: baseline; gap: .6rem; flex-wrap: wrap; }
.pilot-banner-inner strong { color: #6a4f10; font-weight: 500; }

/* ── Language toggle ───────────────────────────────────────────────────────── */
.lang-toggle { display: flex; gap: 0; border: 1px solid var(--rule-strong); border-radius: 3px; overflow: hidden; width: fit-content; }
.lang-btn { font-family: var(--mono); font-size: .62rem; letter-spacing: .1em; text-transform: uppercase; padding: .3em .9em; background: var(--paper); color: var(--ink-soft); border: none; border-right: 1px solid var(--rule-strong); cursor: pointer; transition: all .12s; user-select: none; }
.lang-btn:last-child { border-right: none; }
.lang-btn:hover { background: var(--paper-warm); color: var(--ink); }
.lang-btn.active { background: var(--green); color: #fff; }

/* ── Breadcrumb ────────────────────────────────────────────────────────────── */
.breadcrumb { font-family: var(--mono); font-size: .7rem; letter-spacing: .08em; color: var(--ink-soft); padding: 1rem 0 0; }
.breadcrumb a { color: var(--ink-soft); }
.breadcrumb a:hover { color: var(--green); }
.breadcrumb span { margin: 0 .4em; opacity: .5; }

/* ── Medjat root hero ──────────────────────────────────────────────────────── */
.medjat-hero { padding: 3.5rem 0 3rem; border-bottom: 2px solid var(--ink); }
.medjat-hero-inner { display: grid; grid-template-columns: 1fr auto; gap: 3rem; align-items: start; }
.medjat-eyebrow { font-family: var(--mono); font-size: .68rem; letter-spacing: .18em; text-transform: uppercase; color: var(--green-mid); margin-bottom: .6rem; }
.medjat-title-block { display: flex; align-items: flex-start; gap: 1.5rem; }
.medjat-glyph { flex-shrink: 0; width: 80px; }
.medjat-glyph-box { width: 80px; border: 1px solid var(--rule-strong); background: var(--paper-warm); display: flex; flex-direction: column; align-items: center; justify-content: center; padding: .5rem; gap: .3rem; }
.medjat-glyph-inner { font-family: 'Noto Sans Egyptian Hieroglyphs', serif; font-size: 1.8rem; line-height: 1; color: var(--ink-mid); letter-spacing: .05em; }
.medjat-glyph-label { font-family: var(--mono); font-size: .5rem; letter-spacing: .12em; text-transform: uppercase; color: var(--ink-soft); }
.medjat-title { font-family: var(--serif); font-size: clamp(2.4rem,5vw,4rem); font-weight: 600; color: var(--green); line-height: 1; }
.medjat-title em { font-style: italic; color: var(--terracotta); font-size: .7em; }
.medjat-sub { font-size: .92rem; color: var(--ink-mid); margin-top: .9rem; max-width: 52ch; line-height: 1.75; }
.medjat-definition { margin-top: 1.5rem; padding-top: 1.25rem; border-top: 1px solid var(--rule); font-family: var(--mono); font-size: .72rem; color: var(--ink-soft); line-height: 1.65; }
.medjat-definition strong { color: var(--ink-mid); font-weight: 500; }

/* ── Stats panel ───────────────────────────────────────────────────────────── */
.stats-panel { background: var(--paper-warm); border: 1px solid var(--rule-strong); border-radius: 3px; padding: 1.5rem; min-width: 220px; }
.stats-kicker { font-family: var(--mono); font-size: .62rem; letter-spacing: .15em; text-transform: uppercase; color: var(--ink-soft); margin-bottom: 1rem; }
.stat-row { display: flex; flex-direction: column; gap: .75rem; }
.stat-item { display: grid; grid-template-columns: 3rem 1fr; gap: .5rem; align-items: baseline; padding-bottom: .75rem; border-bottom: 1px solid var(--rule); }
.stat-item:last-child { border-bottom: none; padding-bottom: 0; }
.stat-num { font-family: var(--serif); font-size: 1.6rem; font-weight: 600; color: var(--green); line-height: 1; }
.stat-label { font-size: .8rem; color: var(--ink-soft); line-height: 1.4; }

/* ── Section titles ────────────────────────────────────────────────────────── */
.section-title { font-family: var(--mono); font-size: .65rem; letter-spacing: .18em; text-transform: uppercase; color: var(--ink-soft); padding-bottom: .5rem; border-bottom: 1px solid var(--rule-strong); margin: 3rem 0 1.5rem; }

/* ── Collection grid ───────────────────────────────────────────────────────── */
.collection-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 1px; border: 1px solid var(--rule-strong); border-radius: 3px; overflow: hidden; background: var(--rule-strong); margin-bottom: 2rem; }
.collection-card { background: var(--paper); padding: 1.4rem 1.6rem; display: flex; flex-direction: column; gap: .5rem; }
.collection-card.live { transition: background .12s; }
.collection-card.live:hover { background: var(--paper-warm); }
.collection-card.planned { opacity: .72; cursor: default; }
.collection-name { font-family: var(--serif); font-size: 1.25rem; font-weight: 600; color: var(--green); }
.collection-desc { font-size: .85rem; color: var(--ink-mid); line-height: 1.6; }
.collection-meta { margin-top: .5rem; font-family: var(--mono); font-size: .65rem; letter-spacing: .06em; color: var(--ink-soft); }
.status-pill { display: inline-block; font-family: var(--mono); font-size: .58rem; letter-spacing: .06em; text-transform: uppercase; padding: .15em .6em; border-radius: 2px; border: 1px solid var(--rule-strong); background: var(--paper-deep); color: var(--ink-soft); }
.status-pill.live { background: var(--green-light); color: var(--green); border-color: transparent; }

/* ── Note blocks ───────────────────────────────────────────────────────────── */
.note-block { border-left: 3px solid var(--green); padding: .85rem 1.1rem; background: var(--green-light); border-radius: 0 3px 3px 0; margin-bottom: 1rem; }
.note-block-title { font-family: var(--mono); font-size: .62rem; letter-spacing: .12em; text-transform: uppercase; color: var(--green); margin-bottom: .4rem; }
.note-block p { font-size: .86rem; color: var(--ink-mid); line-height: 1.65; }

/* ── Ewé collection — explorer hero ───────────────────────────────────────── */
.explorer-hero { padding: 3rem 0 2.5rem; border-bottom: 2px solid var(--ink); }
.hero-inner { display: grid; grid-template-columns: auto 1fr auto; gap: 2.5rem; align-items: start; }
.hero-logo { width: 88px; height: 88px; display: grid; place-items: center; }
.hero-logo img { width: 100%; height: 100%; object-fit: contain; border-radius: 50%; }
.hero-logo-fallback { width: 88px; height: 88px; border: 1px solid var(--rule-strong); border-radius: 50%; display: grid; place-items: center; font-family: var(--serif); font-size: 1.5rem; color: var(--green); background: var(--paper-warm); }
.explorer-eyebrow { font-family: var(--mono); font-size: .68rem; letter-spacing: .18em; text-transform: uppercase; color: var(--green-mid); margin-bottom: .5rem; }
.explorer-title { font-family: var(--serif); font-size: clamp(1.8rem,3.5vw,2.8rem); font-weight: 600; color: var(--green); line-height: 1.05; }
.explorer-title em { font-style: italic; color: var(--terracotta); }
.explorer-sub { font-size: .88rem; color: var(--ink-mid); margin-top: .75rem; max-width: 58ch; line-height: 1.65; }
.about-block { border-left: 3px solid var(--green); padding: .85rem 1.1rem; background: var(--green-light); border-radius: 0 3px 3px 0; margin: 2rem 0 0; }
.about-block-title { font-family: var(--mono); font-size: .65rem; letter-spacing: .15em; text-transform: uppercase; color: var(--green); margin-bottom: .5rem; }
.about-block p { font-size: .84rem; color: var(--ink-mid); line-height: 1.65; }

/* ── Search and filter toolbar ─────────────────────────────────────────────── */
.toolbar { margin: 2rem 0 1rem; display: flex; gap: .75rem; align-items: center; flex-wrap: wrap; }
.toolbar-grid { display: grid; grid-template-columns: minmax(260px,1fr) auto 220px; gap: .75rem; align-items: center; }
.search-input { flex: 1; min-width: 220px; font-family: var(--sans); font-size: .88rem; padding: .5em 1em; border: 1px solid var(--rule-strong); border-radius: 3px; background: var(--paper); color: var(--ink); outline: none; transition: border-color .15s; }
.search-input:focus { border-color: var(--green); }
.search-count { font-family: var(--mono); font-size: .68rem; color: var(--ink-soft); white-space: nowrap; }
.access-select { padding: .7rem .85rem; border: 1px solid var(--rule-strong); background: var(--paper); font-family: var(--mono); font-size: .68rem; letter-spacing: .04em; color: var(--ink); }
.filter-row { display: flex; gap: .4rem; flex-wrap: wrap; margin-bottom: 1.5rem; }
.filter-pill { font-family: var(--mono); font-size: .6rem; letter-spacing: .07em; text-transform: uppercase; padding: .22em .75em; border-radius: 2px; border: 1px solid var(--rule-strong); background: var(--paper); color: var(--ink-soft); cursor: pointer; transition: all .12s; user-select: none; }
.filter-pill:hover { background: var(--paper-warm); color: var(--ink); }
.filter-pill.active { background: var(--green); color: #fff; border-color: var(--green); }

/* ── Plant grid and cards ──────────────────────────────────────────────────── */
.plant-grid { display: grid; grid-template-columns: repeat(auto-fill,minmax(300px,1fr)); gap: 1px; border: 1px solid var(--rule-strong); border-radius: 3px; overflow: hidden; background: var(--rule-strong); margin-bottom: 2rem; }
.plant-card { background: var(--paper); padding: 1.2rem 1.4rem; transition: background .12s; display: flex; flex-direction: column; gap: .3rem; cursor: pointer; }
.plant-card:hover { background: var(--paper-warm); }
.plant-card.hidden { display: none; }
.card-id { font-family: var(--mono); font-size: .58rem; letter-spacing: .1em; color: var(--ink-soft); text-transform: uppercase; }
.card-pref { font-family: var(--serif); font-size: 1.15rem; font-weight: 600; color: var(--green); line-height: 1.15; }
.card-sci { font-size: .76rem; font-style: italic; color: var(--ink-soft); }
.card-names { display: flex; flex-direction: column; gap: .1rem; margin-top: .25rem; }
.card-name-row { display: grid; grid-template-columns: 28px 1fr; gap: .4rem; align-items: baseline; }
.card-name-lang { font-family: var(--mono); font-size: .52rem; letter-spacing: .08em; text-transform: uppercase; color: var(--ink-soft); }
.card-name-val { font-size: .78rem; color: var(--ink-mid); }
.card-foot { margin-top: .5rem; display: flex; gap: .4rem; flex-wrap: wrap; align-items: center; }

/* ── Access badges ─────────────────────────────────────────────────────────── */
.access-badge { display: inline-block; font-family: var(--mono); font-size: .58rem; letter-spacing: .06em; padding: .12em .55em; border-radius: 2px; white-space: nowrap; }
.access-badge-lg { font-size: .72rem; padding: .2em .7em; }
.access-public { background: var(--green-light); color: var(--green); }
.access-community { background: var(--gold-light); color: var(--gold); }
.access-initiated { background: #fde8e0; color: var(--terracotta); }
.access-none { background: #2a2a2a; color: #fff; }

/* ── Plant detail header ───────────────────────────────────────────────────── */
.plant-header { padding: 2.5rem 0 2rem; border-bottom: 2px solid var(--ink); }
.plant-header-inner { display: grid; grid-template-columns: 1fr auto; gap: 2rem; align-items: start; }
.plant-pref-large { font-family: var(--serif); font-size: clamp(2rem,4vw,3rem); font-weight: 600; color: var(--green); line-height: 1.05; }
.plant-sci-large { font-size: 1rem; font-style: italic; color: var(--ink-soft); margin-top: .3rem; }
.plant-id-label { font-family: var(--mono); font-size: .65rem; letter-spacing: .12em; text-transform: uppercase; color: var(--ink-soft); margin-top: .5rem; }
.plant-header-meta { display: flex; gap: .5rem; flex-wrap: wrap; align-items: center; margin-top: .85rem; }

/* ── Detail grid (plant page) ──────────────────────────────────────────────── */
.detail-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 3rem; margin: 2.5rem 0; }
.detail-section-title { font-family: var(--mono); font-size: .65rem; letter-spacing: .18em; text-transform: uppercase; color: var(--ink-soft); padding-bottom: .5rem; border-bottom: 1px solid var(--rule-strong); margin-bottom: 1.2rem; }
.detail-row { margin-bottom: 1rem; }
.detail-label { font-family: var(--mono); font-size: .63rem; letter-spacing: .1em; text-transform: uppercase; color: var(--ink-soft); margin-bottom: .3rem; }
.names-table { width: 100%; border-collapse: collapse; }
.names-table tr { border-bottom: 1px solid var(--rule); }
.names-table tr:last-child { border-bottom: none; }
.names-table td { padding: .55rem 0; vertical-align: top; }
.names-table td:first-child { font-family: var(--mono); font-size: .6rem; letter-spacing: .1em; text-transform: uppercase; color: var(--ink-soft); white-space: nowrap; padding-right: 1rem; width: 130px; padding-top: .65rem; }
.name-empty { font-family: var(--mono); font-size: .68rem; color: var(--ink-soft); font-style: italic; }
.use-value { display: inline-block; font-size: .85rem; font-weight: 400; color: var(--ink); background: var(--paper-warm); border: 1px solid var(--rule-strong); padding: .2em .75em; border-radius: 2px; }
.tag-cloud { display: flex; flex-wrap: wrap; gap: .35rem; }
.tag-pill { font-family: var(--sans); font-size: .73rem; background: var(--paper-deep); color: var(--ink-mid); padding: .18em .65em; border-radius: 2px; border: 1px solid var(--rule-strong); line-height: 1.4; }
.collision-notice { display: inline-flex; align-items: center; gap: .4rem; font-family: var(--mono); font-size: .62rem; letter-spacing: .06em; color: var(--gold); background: var(--gold-light); border: 1px solid rgba(160,120,48,.25); padding: .18em .65em; border-radius: 2px; }
.mono-link { font-family: var(--mono); font-size: .72rem; word-break: break-all; color: var(--green-mid); }
.stack-block { margin: 0 0 1rem; }
.assertion-line { display: grid; gap: .2rem; margin: .45rem 0; }
.assertion-line .assertion-key { font-family: var(--mono); font-size: .58rem; letter-spacing: .08em; text-transform: uppercase; color: var(--ink-soft); }
.assertion-line .assertion-value { font-size: .9rem; color: var(--ink-mid); line-height: 1.5; }
.assertion-line.block .assertion-value { background: var(--paper-warm); border: 1px solid var(--rule-strong); border-radius: 3px; padding: .85rem 1rem; }
.placeholder-line .assertion-value { font-family: var(--mono); font-size: .68rem; color: var(--ink-soft); font-style: italic; }
.redaction-block { background: #f8f5ef; border: 1px dashed #b69f74; border-radius: 3px; padding: .85rem 1rem; margin: .45rem 0; }
.redaction-top { display: flex; gap: .5rem; flex-wrap: wrap; align-items: center; margin-bottom: .45rem; }
.redaction-helper { font-size: .82rem; line-height: 1.55; color: var(--ink-mid); }
.governance-box { background: var(--paper-warm); border: 1px solid var(--rule-strong); padding: .9rem 1rem; border-radius: 3px; }
.record-governance-copy { font-size: .9rem; font-weight: 600; color: var(--ink); margin-bottom: .3rem; }
.governance-helper { font-size: .82rem; line-height: 1.55; color: var(--ink-mid); }
.scientific-display { margin-top: .3rem; font-style: italic; font-size: .9rem; color: var(--ink-mid); }

/* ── Plant navigation ──────────────────────────────────────────────────────── */
.plant-nav { display: flex; justify-content: space-between; align-items: center; padding: 1.5rem 0; border-top: 1px solid var(--rule); margin-top: 2rem; gap: .5rem; flex-wrap: wrap; }
.plant-nav a { font-family: var(--mono); font-size: .68rem; letter-spacing: .08em; text-transform: uppercase; color: var(--ink-soft); border: 1px solid var(--rule-strong); padding: .3em .9em; border-radius: 2px; transition: all .12s; }
.plant-nav a:hover { background: var(--paper-warm); color: var(--ink); }

/* ── Placeholder collection pages ──────────────────────────────────────────── */
.collection-placeholder { padding: 4rem 0 3rem; border-bottom: 2px solid var(--ink); }
.placeholder-badge { font-family: var(--mono); font-size: .65rem; letter-spacing: .18em; text-transform: uppercase; color: var(--ink-soft); border: 1px solid var(--rule-strong); padding: .2em .75em; border-radius: 2px; display: inline-block; margin-bottom: 1.2rem; }
.placeholder-title { font-family: var(--serif); font-size: clamp(2rem,4vw,3.2rem); font-weight: 600; color: var(--green); line-height: 1.05; margin-bottom: .75rem; }
.placeholder-sub { font-size: .92rem; color: var(--ink-mid); max-width: 52ch; line-height: 1.75; }
.placeholder-body { padding: 3rem 0; }
.placeholder-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 2rem; margin-top: 1.5rem; }
.placeholder-item { border-left: 3px solid var(--rule-strong); padding-left: 1rem; }
.placeholder-item-title { font-family: var(--mono); font-size: .65rem; letter-spacing: .12em; text-transform: uppercase; color: var(--ink-soft); margin-bottom: .4rem; }
.placeholder-item-desc { font-size: .86rem; color: var(--ink-mid); line-height: 1.6; }
.notify-block { background: var(--paper-warm); border: 1px solid var(--rule-strong); border-radius: 3px; padding: 1.2rem 1.4rem; margin-top: 2rem; }
.notify-title { font-family: var(--mono); font-size: .65rem; letter-spacing: .12em; text-transform: uppercase; color: var(--ink-soft); margin-bottom: .5rem; }

/* ── Shared footer ─────────────────────────────────────────────────────────── */
.site-footer { border-top: 1px solid var(--rule); padding: 1.5rem 0 2.5rem; display: flex; gap: 2rem; flex-wrap: wrap; justify-content: space-between; align-items: center; margin-top: 2rem; }
.footer-left { font-family: var(--mono); font-size: .68rem; letter-spacing: .04em; color: var(--ink-soft); line-height: 1.7; }
.footer-links { display: flex; gap: 1.5rem; flex-wrap: wrap; }
.footer-links a { font-family: var(--mono); font-size: .68rem; letter-spacing: .05em; color: var(--ink-soft); }
.footer-links a:hover { color: var(--green); }

/* ── Responsive ────────────────────────────────────────────────────────────── */
@media (max-width: 760px) {
  .medjat-hero-inner { grid-template-columns: 1fr; gap: 1.5rem; }
  .medjat-title-block { flex-direction: column; }
  .stats-panel { min-width: 0; }
  .collection-grid { grid-template-columns: 1fr; }
  .hero-inner { grid-template-columns: 1fr; gap: 1rem; }
  .hero-logo { width: 52px; height: 52px; }
  .hero-logo-fallback { width: 52px; height: 52px; font-size: 1rem; }
  .detail-grid { grid-template-columns: 1fr; gap: 1.5rem; }
  .plant-grid { grid-template-columns: 1fr; }
  .plant-header-inner { grid-template-columns: 1fr; }
  .toolbar-grid { grid-template-columns: 1fr; }
  .access-select { width: 100%; }
  .placeholder-grid { grid-template-columns: 1fr; }
}
