/* RLTV Case Library — Frontend Styles */
.rltv-cl-app { font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif; color:#1e293b; }

/* Header */
.rltv-cl-header { background:linear-gradient(135deg,#1a2744,#253357); color:#fff; padding:36px 32px 32px; border-radius:8px; margin-bottom:24px; border-bottom:3px solid #c0392b; }
.rltv-cl-title { color:#fff!important; font-size:clamp(1.5rem,3vw,2rem); margin:0 0 8px; }
.rltv-cl-subtitle { color:rgba(255,255,255,.8); margin:0; font-size:.9rem; line-height:1.6; max-width:680px; }

/* Search bar */
.rltv-cl-search-bar { display:flex; gap:10px; margin-bottom:12px; align-items:center; }
.rltv-cl-search-wrap { position:relative; flex:1; }
.rltv-search-icon { position:absolute; left:12px; top:50%; transform:translateY(-50%); color:#94a3b8; pointer-events:none; }
.rltv-cl-search-input { width:100%; padding:11px 14px 11px 36px; border:1.5px solid #e2e8f0; border-radius:6px; font-size:.95rem; transition:border-color .18s; box-sizing:border-box; }
.rltv-cl-search-input:focus { outline:none; border-color:#1a2744; box-shadow:0 0 0 3px rgba(26,39,68,.08); }
.rltv-cl-btn-filter { display:flex; align-items:center; gap:6px; padding:10px 16px; background:#fff; border:1.5px solid #e2e8f0; border-radius:6px; font-size:.88rem; font-weight:600; color:#475569; cursor:pointer; white-space:nowrap; transition:border-color .18s; }
.rltv-cl-btn-filter:hover { border-color:#1a2744; color:#1a2744; }
.rltv-cl-filter-badge { background:#c0392b; color:#fff; border-radius:10px; padding:1px 7px; font-size:.72rem; }

/* Filters */
.rltv-cl-filters { background:#f8fafc; border:1px solid #e2e8f0; border-radius:8px; padding:20px 24px; margin-bottom:16px; }
.rltv-cl-filter-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:14px 20px; }
.rltv-cl-filter-group label { display:block; font-size:.78rem; font-weight:600; color:#475569; text-transform:uppercase; letter-spacing:.05em; margin-bottom:5px; }
.rltv-cl-select, .rltv-cl-input-year { width:100%; padding:8px 10px; border:1.5px solid #e2e8f0; border-radius:5px; font-size:.88rem; background:#fff; }
.rltv-cl-select:focus, .rltv-cl-input-year:focus { outline:none; border-color:#1a2744; }
.rltv-cl-filter-actions { display:flex; gap:8px; margin-top:14px; padding-top:14px; border-top:1px solid #e2e8f0; }
.rltv-cl-btn-secondary { background:none; border:1.5px solid #e2e8f0; border-radius:5px; padding:6px 14px; font-size:.82rem; font-weight:600; color:#64748b; cursor:pointer; }
.rltv-cl-btn-secondary:hover { border-color:#1a2744; color:#1a2744; }

/* Results meta */
.rltv-cl-results-meta { display:flex; justify-content:space-between; align-items:center; margin-bottom:14px; font-size:.85rem; color:#64748b; }
.rltv-cl-sort { display:flex; align-items:center; gap:6px; }
.rltv-cl-sort select { padding:5px 8px; border:1px solid #e2e8f0; border-radius:4px; font-size:.82rem; }

/* Loading */
.rltv-cl-loading { text-align:center; padding:48px; color:#64748b; }
.rltv-cl-spinner { width:32px; height:32px; border:3px solid #e2e8f0; border-top-color:#c0392b; border-radius:50%; animation:cl-spin .8s linear infinite; display:inline-block; margin-bottom:12px; }
@keyframes cl-spin { to { transform:rotate(360deg); } }

/* Results */
.rltv-cl-results { display:flex; flex-direction:column; gap:14px; }

.rltv-cl-case-card { background:#fff; border:1px solid #e2e8f0; border-radius:8px; padding:20px 22px; transition:box-shadow .18s,border-color .18s; }
.rltv-cl-case-card:hover { box-shadow:0 4px 16px rgba(26,39,68,.1); border-color:#c9a84c; }

.rltv-cl-case-header { display:flex; justify-content:space-between; align-items:flex-start; gap:12px; margin-bottom:8px; }
.rltv-cl-case-name { font-family:'Playfair Display',Georgia,serif; font-size:1.1rem; font-weight:700; color:#1a2744; margin:0; line-height:1.3; }
.rltv-cl-case-name a { color:inherit; text-decoration:none; }
.rltv-cl-case-name a:hover { color:#c0392b; }
.rltv-cl-case-year { font-size:.8rem; font-weight:700; color:#94a3b8; white-space:nowrap; padding-top:2px; }

.rltv-cl-case-meta { display:flex; flex-wrap:wrap; gap:12px; font-size:.78rem; color:#475569; margin-bottom:10px; }
.rltv-cl-case-meta-item strong { color:#334155; }

.rltv-cl-case-holding { font-size:.88rem; color:#475569; line-height:1.6; margin-bottom:12px; }

.rltv-cl-case-topics { display:flex; flex-wrap:wrap; gap:5px; margin-bottom:12px; }
.rltv-cl-topic-pill { display:inline-block; background:#eff6ff; border:1px solid #bfdbfe; border-radius:12px; padding:2px 9px; font-size:.72rem; font-weight:600; color:#1e40af; text-decoration:none; white-space:nowrap; }
.rltv-cl-topic-pill:hover { background:#dbeafe; }

.rltv-cl-outcome-badge { display:inline-block; border-radius:12px; padding:2px 10px; font-size:.72rem; font-weight:700; text-transform:uppercase; letter-spacing:.05em; }
.outcome-prevailed      { background:#dcfce7; color:#166534; }       /* Claimant Prevailed / Settled */
.outcome-not-prevailed  { background:#ede9fe; color:#5b21b6; }       /* Claimant Did Not Prevail */
.outcome-govt           { background:#ffedd5; color:#9a3412; }       /* Government Prevailed */
.outcome-split          { background:#fef9c3; color:#854d0e; }       /* Split Decision */
.outcome-procedural     { background:#f1f5f9; color:#475569; }       /* Remanded / Dismissed / Vacated */
.outcome-pending        { background:#dbeafe; color:#1e40af; }       /* Pending */
.outcome-unknown        { background:#f1f5f9; color:#64748b; }

.rltv-cl-case-actions { display:flex; flex-wrap:wrap; gap:8px; align-items:center; padding-top:12px; border-top:1px solid #f1f5f9; }
.rltv-cl-doc-link { display:inline-flex; align-items:center; gap:5px; padding:5px 12px; border-radius:4px; font-size:.78rem; font-weight:600; text-decoration:none; transition:background .15s; }
.rltv-cl-doc-link--opinion { background:#c0392b; color:#fff; }
.rltv-cl-doc-link--opinion:hover { background:#1a2744; color:#fff; }
.rltv-cl-doc-link--secondary { background:#f1f5f9; color:#475569; border:1px solid #e2e8f0; }
.rltv-cl-doc-link--secondary:hover { background:#e2e8f0; }
.rltv-cl-btn-synopsis { background:none; border:1.5px solid #1a2744; border-radius:4px; padding:5px 12px; font-size:.78rem; font-weight:600; color:#1a2744; cursor:pointer; transition:background .15s,color .15s; }
.rltv-cl-btn-synopsis:hover { background:#1a2744; color:#fff; }
.rltv-cl-source-link { font-size:.75rem; color:#94a3b8; text-decoration:none; margin-left:auto; }
.rltv-cl-source-link:hover { color:#64748b; }

/* Source toggle & relationship badges */
.rltv-cl-source-toggle { background:none; border:none; font-size:.75rem; color:#94a3b8; cursor:pointer; padding:0; margin-left:auto; white-space:nowrap; }
.rltv-cl-source-toggle:hover { color:#475569; }
.rltv-cl-card-sources { border-top:1px solid #f1f5f9; padding:12px 0 0; margin-top:10px; }
.rltv-cl-source-item { display:flex; flex-direction:column; gap:4px; padding:8px 0; border-bottom:1px solid #f8fafc; }
.rltv-cl-source-item:last-child { border:none; padding-bottom:0; }
.rltv-cl-source-main { display:flex; justify-content:space-between; align-items:flex-start; gap:8px; font-size:.85rem; }
.rltv-cl-source-main a { color:#1a2744; text-decoration:none; font-weight:600; line-height:1.4; }
.rltv-cl-source-main a:hover { color:#c0392b; }
.rltv-cl-source-meta { display:flex; align-items:center; gap:8px; flex-wrap:wrap; }
.rltv-cl-rel-badge { display:inline-block; padding:2px 8px; border-radius:10px; font-size:.68rem; font-weight:700; text-transform:uppercase; letter-spacing:.04em; cursor:default; }
.rel-primary   { background:#fef9c3; color:#854d0e; border:1px solid #fde68a; }
.rel-context   { background:#eff6ff; color:#1e40af; border:1px solid #bfdbfe; }
.rel-mentioned { background:#f8fafc; color:#64748b; border:1px solid #e2e8f0; }
.rel-unknown   { background:#f8fafc; color:#64748b; border:1px solid #e2e8f0; }
.rltv-cl-source-doc-link { font-size:.82rem; color:#475569; text-decoration:none; }
.rltv-cl-source-doc-link:hover { color:#c0392b; }
.rltv-cl-article-doc-links { display:flex; flex-wrap:wrap; gap:8px; align-items:center; margin-bottom:14px; padding:12px 16px; background:#fefce8; border:1px solid #fde68a; border-radius:6px; }
.rltv-cl-article-doc-note { font-size:.78rem; font-weight:700; color:#854d0e; margin-right:4px; }
.rltv-cl-doc-btn--article { background:#fff; border-color:#fde68a; color:#854d0e; }
.rltv-cl-doc-btn--article:hover { background:#854d0e; border-color:#854d0e; color:#fff; }

/* No results */
.rltv-cl-no-results { text-align:center; padding:48px; color:#94a3b8; }
.rltv-cl-no-results p { margin:12px 0; font-size:.9rem; }

/* Pagination */
.rltv-cl-pagination { display:flex; gap:6px; justify-content:center; padding:24px 0 8px; flex-wrap:wrap; }
.rltv-cl-page-btn { padding:6px 14px; border:1.5px solid #e2e8f0; border-radius:4px; background:#fff; font-size:.82rem; cursor:pointer; font-weight:600; color:#475569; transition:all .15s; }
.rltv-cl-page-btn:hover, .rltv-cl-page-btn.active { background:#1a2744; color:#fff; border-color:#1a2744; }

/* Modal */
.rltv-cl-modal { position:fixed; inset:0; z-index:99999; display:flex; align-items:center; justify-content:center; }
.rltv-cl-modal-overlay { position:absolute; inset:0; background:rgba(0,0,0,.55); }
.rltv-cl-modal-box { position:relative; background:#fff; border-radius:10px; width:min(720px,94vw); max-height:88vh; display:flex; flex-direction:column; box-shadow:0 24px 60px rgba(0,0,0,.25); }
.rltv-cl-modal-header { display:flex; justify-content:space-between; align-items:center; padding:20px 24px 16px; border-bottom:2px solid #e2e8f0; background:#1a2744; border-radius:10px 10px 0 0; }
.rltv-cl-modal-header h3 { color:#fff!important; margin:0; font-size:1.05rem; }
.rltv-cl-modal-close { background:none; border:none; color:rgba(255,255,255,.7); font-size:1.2rem; cursor:pointer; padding:2px 6px; line-height:1; border-radius:3px; }
.rltv-cl-modal-close:hover { color:#fff; background:rgba(255,255,255,.15); }
.rltv-cl-modal-meta { padding:14px 24px; background:#f8fafc; border-bottom:1px solid #e2e8f0; font-size:.82rem; color:#475569; display:flex; flex-wrap:wrap; gap:12px; }
.rltv-cl-modal-meta strong { color:#334155; }
.rltv-cl-modal-body { padding:24px; overflow-y:auto; flex:1; }
.rltv-cl-modal-footer { padding:14px 24px; border-top:1px solid #e2e8f0; display:flex; flex-wrap:wrap; gap:8px; align-items:center; }

/* Synopsis styles */
.rltv-cl-synopsis-loading { text-align:center; padding:32px; color:#64748b; }
.rltv-synopsis-heading { color:#1a2744; font-size:.95rem; text-transform:uppercase; letter-spacing:.06em; margin:20px 0 6px; padding-bottom:4px; border-bottom:2px solid #e2e8f0; }
.rltv-synopsis-heading:first-child { margin-top:0; }
#rltv-cl-synopsis-content p, .rltv-cl-synopsis p { font-size:.92rem; line-height:1.75; color:#334155; margin:0 0 10px; }
#rltv-cl-synopsis-content ul, .rltv-cl-synopsis ul { padding-left:20px; margin:0 0 10px; font-size:.88rem; color:#475569; }
.rltv-synopsis-divider { border:none; border-top:1px solid #e2e8f0; margin:16px 0; }

/* Single case page */
.rltv-cl-single { margin-bottom:32px; }
.rltv-cl-single-meta { display:flex; flex-wrap:wrap; gap:16px; background:#f8fafc; border:1px solid #e2e8f0; border-radius:6px; padding:16px 20px; margin-bottom:16px; font-size:.85rem; }
.rltv-cl-meta-item { color:#334155; }
.rltv-cl-single-topics { display:flex; flex-wrap:wrap; gap:6px; margin-bottom:16px; }
.rltv-cl-holding { background:#fff8e7; border:1px solid #f0d58a; border-left:4px solid #c9a84c; padding:14px 18px; border-radius:0 6px 6px 0; font-size:.9rem; line-height:1.65; color:#1a2744; margin-bottom:20px; }
.rltv-cl-documents { margin:24px 0; padding:20px 22px; background:#f8fafc; border:1px solid #e2e8f0; border-radius:8px; }
.rltv-cl-documents h3 { color:#1a2744; margin:0 0 14px; font-size:1rem; }
.rltv-cl-doc-links { display:flex; flex-wrap:wrap; gap:10px; }
.rltv-cl-doc-btn { display:inline-flex; flex-direction:column; align-items:center; padding:12px 20px; border-radius:6px; font-size:.85rem; font-weight:600; text-decoration:none; border:1.5px solid #e2e8f0; background:#fff; color:#334155; transition:all .15s; }
.rltv-cl-doc-btn:hover { border-color:#1a2744; background:#1a2744; color:#fff; }
.rltv-cl-doc-btn--pdf { background:#c0392b; border-color:#c0392b; color:#fff; }
.rltv-cl-doc-btn--pdf:hover { background:#1a2744; border-color:#1a2744; }
.rltv-cl-doc-btn small { font-size:.7rem; font-weight:normal; opacity:.75; margin-top:2px; }
.rltv-cl-sources { margin:24px 0; }
.rltv-cl-sources h3 { color:#1a2744; margin:0 0 12px; font-size:1rem; }
.rltv-cl-source-list { list-style:none; padding:0; margin:0; }
.rltv-cl-source-list a { color:#1a2744; text-decoration:none; font-weight:600; }
.rltv-cl-source-list a:hover { color:#c0392b; }
.rltv-cl-source-date { color:#94a3b8; font-size:.78rem; }
.rltv-cl-synopsis-cta { display:flex; align-items:center; gap:12px; padding:16px 20px; background:#f8fafc; border:1px solid #e2e8f0; border-radius:6px; margin:20px 0; }
.rltv-cl-btn-synopsis { background:#1a2744; color:#fff; border:none; border-radius:5px; padding:9px 18px; font-size:.88rem; font-weight:600; cursor:pointer; }
.rltv-cl-btn-synopsis:hover { background:#c0392b; }
.rltv-cl-synopsis-note { font-size:.78rem; color:#94a3b8; }
.rltv-cl-synopsis { border-top:2px solid #e2e8f0; padding-top:24px; margin-top:24px; }

@media(max-width:700px) {
    .rltv-cl-header { padding:24px 18px; }
    .rltv-cl-filter-grid { grid-template-columns:1fr 1fr; }
    .rltv-cl-search-bar { flex-wrap:wrap; }
    .rltv-cl-case-header { flex-direction:column; gap:4px; }
    .rltv-cl-modal-box { max-height:96vh; }
}
