/* ============================================================
   Civys — Legacy brief-class compatibility shim
   ------------------------------------------------------------
   This file re-implements the older brief-class vocabulary
   (.obligation-item, .scope-list, .ambiguity-item, .subsection,
   .tag.tag-*, etc.) using the *new* civys design tokens, so
   briefs that were saved under the previous design still render
   cleanly in the new UI. Load AFTER civys.css + civys-app.css on
   pages that may render historical briefs (analyze, history,
   compare). Do NOT redefine design tokens here.
   ============================================================ */

/* Subsection wrappers (older summarization / scope output) */
.subsection {
    background: var(--paper-raised);
    border: 1px solid var(--paper-edge);
    border-radius: var(--r-lg);
    padding: var(--s5);
    margin-bottom: var(--s4);
}
.subsection-title {
    font-family: 'Source Serif 4', Georgia, serif;
    font-size: 1.1rem;
    font-weight: 600;
    color: var(--ink-strong);
    letter-spacing: -.01em;
    margin: 0 0 var(--s3);
}
.subsection-content > p,
.subsection-content > ul,
.subsection-content > ol { color: var(--ink-soft); }
.subsection-content > ul,
.subsection-content > ol { padding-left: 1.25rem; }
.subsection-content > ul li,
.subsection-content > ol li { margin-bottom: var(--s2); }

/* Inline tag pill family used by older prompts
   (e.g. <span class="tag tag-mandatory">MANDATORY</span>) */
.tag {
    display: inline-block;
    font-family: var(--mono, 'Source Sans 3'), sans-serif;
    font-size: .72rem;
    font-weight: 600;
    letter-spacing: .08em;
    text-transform: uppercase;
    padding: .15rem .5rem;
    border-radius: var(--r-sm);
    margin-right: .35rem;
    line-height: 1.4;
}
.tag.tag-mandatory       { background: var(--accent-soft); color: var(--accent-press); }
.tag.tag-discretionary   { background: var(--slate-soft);  color: var(--slate); }
.tag.tag-conditional     { background: var(--warn-soft);   color: var(--warn); }
.tag.tag-direct          { background: var(--ok-soft);     color: var(--ok); }
.tag.tag-paraphrase      { background: var(--slate-soft);  color: var(--slate); }
.tag.tag-inference       { background: var(--warn-soft);   color: var(--warn); }
.tag.tag-interpretation  { background: var(--risk-soft);   color: var(--risk); }
.tag.tag-covered         { background: var(--ok-soft);     color: var(--ok); }
.tag.tag-excluded        { background: var(--risk-soft);   color: var(--risk); }
.tag.tag-silent          { background: var(--paper-sunk);  color: var(--ink-muted); }
.tag.tag-undefined       { background: var(--warn-soft);   color: var(--warn); }
.tag.tag-flexible        { background: var(--slate-soft);  color: var(--slate); }
.tag.tag-gap             { background: var(--accent-soft); color: var(--accent-press); }

/* Older badge-style obligation cards */
.obligation-item {
    background: var(--paper-raised);
    border: 1px solid var(--paper-edge);
    border-left: 3px solid var(--ink-muted);
    border-radius: var(--r-md);
    padding: var(--s4);
    margin-bottom: var(--s3);
}
.obligation-item.obligation-mandatory     { border-left-color: var(--accent); }
.obligation-item.obligation-discretionary { border-left-color: var(--slate); }
.obligation-item.obligation-conditional   { border-left-color: var(--warn); }
.obligation-badge {
    font-family: var(--mono, 'Source Sans 3'), sans-serif;
    font-size: .72rem;
    font-weight: 600;
    letter-spacing: .08em;
    padding: .15rem .45rem;
    background: var(--paper-sunk);
    color: var(--ink-soft);
    border-radius: var(--r-sm);
    margin-right: var(--s2);
}
.obligation-type {
    display: inline-block;
    font-size: .72rem;
    font-weight: 700;
    letter-spacing: .08em;
    text-transform: uppercase;
    padding: .15rem .5rem;
    border-radius: var(--r-sm);
}
.obligation-type.mandatory     { background: var(--accent-soft); color: var(--accent-press); }
.obligation-type.discretionary { background: var(--slate-soft);  color: var(--slate); }
.obligation-type.conditional   { background: var(--warn-soft);   color: var(--warn); }

.confidence-badge {
    display: inline-block;
    font-size: .72rem;
    font-weight: 700;
    letter-spacing: .08em;
    text-transform: uppercase;
    padding: .15rem .5rem;
    border-radius: var(--r-sm);
    margin-left: var(--s2);
}
.confidence-badge.high   { background: var(--ok-soft);   color: var(--ok); }
.confidence-badge.medium { background: var(--warn-soft); color: var(--warn); }
.confidence-badge.low    { background: var(--risk-soft); color: var(--risk); }

.traceability-tag {
    display: inline-block;
    font-family: var(--mono, 'Source Sans 3'), sans-serif;
    font-size: .72rem;
    color: var(--ink-muted);
    background: var(--paper-sunk);
    padding: .1rem .4rem;
    border-radius: var(--r-sm);
    margin-left: .35rem;
}

/* Older bulleted scope lists */
.scope-list {
    list-style: none;
    padding: 0;
    margin: 0;
}
.scope-list li {
    background: var(--paper-raised);
    border: 1px solid var(--paper-edge);
    border-left: 3px solid var(--ink-muted);
    border-radius: var(--r-md);
    padding: var(--s3) var(--s4);
    margin-bottom: var(--s2);
    color: var(--ink-soft);
}
.scope-list.covered  li { border-left-color: var(--ok); }
.scope-list.excluded li { border-left-color: var(--risk); }
.scope-list.silent   li { border-left-color: var(--ink-muted); border-style: solid solid solid dashed; }

/* Older ambiguity register cards */
.ambiguity-item {
    background: var(--paper-raised);
    border: 1px solid var(--paper-edge);
    border-left: 3px solid var(--accent-line);
    border-radius: var(--r-md);
    padding: var(--s4);
    margin-bottom: var(--s3);
}
.ambiguity-item p { margin: var(--s1) 0; color: var(--ink-soft); }
.ambiguity-badge {
    font-family: var(--mono, 'Source Sans 3'), sans-serif;
    font-size: .72rem;
    font-weight: 600;
    letter-spacing: .08em;
    padding: .15rem .45rem;
    background: var(--paper-sunk);
    color: var(--ink-soft);
    border-radius: var(--r-sm);
    margin-right: var(--s2);
}
.issue-type {
    display: inline-block;
    font-size: .7rem;
    font-weight: 700;
    letter-spacing: .08em;
    text-transform: uppercase;
    padding: .15rem .5rem;
    background: var(--warn-soft);
    color: var(--warn);
    border-radius: var(--r-sm);
}

/* Older "No Conclusion Available" cards */
.no-conclusion-item {
    background: var(--paper-raised);
    border: 1px solid var(--paper-edge);
    border-left: 3px solid var(--slate);
    border-radius: var(--r-md);
    padding: var(--s4);
    margin-bottom: var(--s3);
}
.no-conclusion-item p { margin: var(--s1) 0; color: var(--ink-soft); }
.no-conclusion-item strong { color: var(--ink); }
.no-conclusion-badge {
    font-family: var(--mono, 'Source Sans 3'), sans-serif;
    font-size: .72rem;
    font-weight: 600;
    letter-spacing: .08em;
    padding: .15rem .45rem;
    background: var(--paper-sunk);
    color: var(--ink-soft);
    border-radius: var(--r-sm);
    margin-right: var(--s2);
}
.reason-tag {
    display: inline-block;
    font-size: .7rem;
    font-weight: 700;
    letter-spacing: .08em;
    text-transform: uppercase;
    padding: .15rem .5rem;
    border-radius: var(--r-sm);
}
.reason-tag.text-silent         { background: var(--slate-soft);  color: var(--slate); }
.reason-tag.requires-rulemaking { background: var(--accent-soft); color: var(--accent-press); }
.reason-tag.ambiguous           { background: var(--warn-soft);   color: var(--warn); }

/* Older client-computed metrics box (kept for historical briefs that
   embedded it; new code does NOT inject this — see civys-app.css `.metric`) */
.metrics-summary {
    background: var(--paper-sunk);
    border-left: 3px solid var(--accent);
    border-radius: var(--r-sm);
    padding: var(--s3) var(--s4);
    margin-top: var(--s4);
    color: var(--ink-soft);
    font-size: .92rem;
    line-height: 1.55;
}
.metrics-summary strong { color: var(--ink); }
