/*
 * EntityMap Publisher — entitymap.css
 * Stylesheet for the server-rendered /entitymap.html view.
 * Served from assets/entitymap.css within the plugin folder.
 */

:root {
    --ink:          #1a1a2e;
    --ink2:         #4a4a6a;
    --ink3:         #8888aa;
    --accent:       #2e3192;
    --accent-light: #eeeeff;
    --rule:         #d0d0e8;
    --surface:      #f7f7fc;
    --white:        #ffffff;
    --mono:         ui-monospace, Menlo, 'Courier New', monospace;
}

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

body {
    font-family: Georgia, 'Times New Roman', serif;
    font-size: 15px;
    line-height: 1.8;
    color: var(--ink);
    background: var(--white);
    padding: 2.5rem 1.5rem 4rem;
    max-width: 820px;
    margin: 0 auto;
}

a {
    color: var(--accent);
    text-decoration: none;
    border-bottom: 1px dotted var(--accent);
}
a:hover { border-bottom-style: solid; }

/* ── Site Header ─────────────────────────────────────────── */

#site-header {
    border-top: 4px solid var(--accent);
    border-bottom: 1px solid var(--rule);
    padding: 1.5rem 0 1.25rem;
    margin-bottom: 2rem;
}

#site-title {
    font-size: 22px;
    font-weight: 400;
    margin-bottom: .3rem;
}

#site-desc {
    font-size: 13px;
    color: var(--ink3);
    font-family: var(--mono);
}

#site-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    margin-top: .75rem;
}

.meta-pill {
    font-family: var(--mono);
    font-size: 11px;
    background: var(--surface);
    border: 1px solid var(--rule);
    border-radius: 3px;
    padding: 2px 8px;
    color: var(--ink2);
}

.meta-pill span { color: var(--ink); }

/* ── Entity Cards ────────────────────────────────────────── */

article {
    background: var(--white);
    border: 1px solid var(--rule);
    border-left: 3px solid var(--accent);
    padding: 1.5rem 1.75rem;
    margin-bottom: 1.5rem;
    scroll-margin-top: 1rem;
}

article h2 {
    font-size: 16px;
    font-weight: 400;
    font-family: Georgia, serif;
    color: var(--ink);
    margin-bottom: .3rem;
    display: flex;
    align-items: baseline;
    gap: .6rem;
    flex-wrap: wrap;
}

.entity-type {
    font-family: var(--mono);
    font-size: 10px;
    color: var(--ink3);
    border: 1px solid var(--rule);
    padding: 1px 6px;
    border-radius: 2px;
    font-weight: 400;
}

.entity-alt {
    font-family: var(--mono);
    font-size: 11px;
    color: var(--ink3);
}

.entity-desc {
    font-size: 14px;
    color: var(--ink2);
    margin: .6rem 0 0;
    line-height: 1.65;
}

.entity-publisher {
    font-family: var(--mono);
    font-size: 11px;
    color: var(--ink3);
    margin-top: .35rem;
}

.entity-publisher strong { color: var(--ink2); }

.entity-sameas {
    font-family: var(--mono);
    font-size: 11px;
    margin-top: .4rem;
}

.entity-sameas a {
    color: var(--ink3);
    border-bottom-color: var(--rule);
}

/* ── Relations ───────────────────────────────────────────── */

.relations {
    margin-top: 1rem;
    padding-top: .75rem;
    border-top: 1px solid var(--rule);
}

.rel-label {
    font-family: var(--mono);
    font-size: 10px;
    letter-spacing: .08em;
    text-transform: uppercase;
    color: var(--ink3);
    margin-bottom: .4rem;
}

.rel-list {
    display: flex;
    flex-wrap: wrap;
    gap: 5px;
}

.rel-tag {
    font-family: var(--mono);
    font-size: 11px;
    background: var(--accent-light);
    border: 1px solid #c8c8ee;
    border-radius: 2px;
    padding: 2px 7px;
    color: var(--ink2);
}

.rel-tag .pred {
    color: var(--accent);
    font-weight: 500;
    margin-right: .3rem;
}

.rel-tag a {
    border-bottom: none;
    color: var(--ink2);
}

.rel-tag a:hover { color: var(--accent); }

/* ── Evidence Chunks ─────────────────────────────────────── */

.chunks {
    margin-top: 1rem;
    padding-top: .75rem;
    border-top: 1px solid var(--rule);
}

.chunk-label {
    font-family: var(--mono);
    font-size: 10px;
    letter-spacing: .08em;
    text-transform: uppercase;
    color: var(--ink3);
    margin-bottom: .5rem;
}

blockquote {
    background: var(--surface);
    border-left: 2px solid var(--accent);
    padding: .7rem 1rem;
    margin-bottom: .6rem;
    font-size: 13px;
    color: var(--ink2);
    font-style: italic;
    line-height: 1.6;
    position: relative;
}

blockquote:last-child { margin-bottom: 0; }

blockquote .score {
    position: absolute;
    top: .5rem;
    right: .6rem;
    font-family: var(--mono);
    font-size: 10px;
    color: var(--accent);
    background: var(--accent-light);
    padding: 1px 5px;
    border-radius: 2px;
    font-style: normal;
}

blockquote cite {
    display: block;
    margin-top: .4rem;
    font-size: 11px;
    font-style: normal;
    font-family: var(--mono);
    color: var(--ink3);
}

blockquote cite a {
    color: var(--ink3);
    border-bottom-color: var(--rule);
    font-size: 11px;
}

blockquote .retrieved {
    font-family: var(--mono);
    font-size: 10px;
    color: var(--ink3);
    margin-top: .2rem;
    font-style: normal;
}

/* ── Footer ──────────────────────────────────────────────── */

footer {
    margin-top: 2.5rem;
    padding-top: 1.25rem;
    border-top: 1px solid var(--rule);
    font-family: var(--mono);
    font-size: 11px;
    color: var(--ink3);
    text-align: center;
}

/* ── Responsive ──────────────────────────────────────────── */

@media (max-width: 600px) {
    body { padding: 1.25rem 1rem 3rem; }
    article { padding: 1.1rem 1.1rem; }
}
