/* results.css — extracted from results.html (refactor 2026-05-02) */

* { margin: 0; padding: 0; box-sizing: border-box; }
:root {
    --slate-950: #0a0e1a; --slate-900: #0f1629; --slate-800: #1a2342;
    --slate-700: #283556; --slate-400: #8896b8; --slate-300: #a8b5d0;
    --amber-400: #f5b731; --amber-300: #fcd068; --white: #f0f2f8;
    --green-400: #4ade80; --red-400: #f87171; --blue-400: #60a5fa; --purple-400: #c084fc;
}
body { font-family: 'Plus Jakarta Sans', -apple-system, sans-serif; background: var(--slate-950); color: var(--slate-300); line-height: 1.7; }
body::before { content: ''; position: fixed; top: 0; left: 0; width: 100%; height: 100%; background-image: url('data:image/svg+xml,%3Csvg viewBox=\u00270 0 256 256\u0027 xmlns=\u0027http://www.w3.org/2000/svg\u0027%3E%3Cfilter id=\u0027n\u0027%3E%3CfeTurbulence type=\u0027fractalNoise\u0027 baseFrequency=\u00270.9\u0027 numOctaves=\u00274\u0027 stitchTiles=\u0027stitch\u0027/%3E%3C/filter%3E%3Crect width=\u0027100%25\u0027 height=\u0027100%25\u0027 filter=\u0027url(%23n)\u0027 opacity=\u00270.03\u0027/%3E%3C/svg%3E'); pointer-events: none; z-index: 1; }
.container { max-width: 800px; margin: 0 auto; padding: 0 24px; position: relative; z-index: 2; }
nav { max-width: 1100px; margin: 0 auto; padding: 28px 24px; display: flex; align-items: center; justify-content: space-between; position: relative; z-index: 2; }
.logo { font-family: 'Syne', sans-serif; font-weight: 800; font-size: 1.5rem; color: var(--white); text-decoration: none; }
.logo-dot { color: var(--amber-400); }
.nav-cta { display: inline-flex; align-items: center; gap: 8px; padding: 10px 24px; background: var(--amber-400); color: var(--slate-950); font-weight: 700; font-size: 0.9rem; border-radius: 8px; text-decoration: none; transition: all 0.2s; }
.nav-cta:hover { background: var(--amber-300); }
.loading { text-align: center; padding: 100px 0; }
.spinner { width: 40px; height: 40px; border: 3px solid var(--slate-700); border-top-color: var(--amber-400); border-radius: 50%; animation: spin 0.8s linear infinite; margin: 0 auto 20px; }
@keyframes spin { to { transform: rotate(360deg); } }

/* ── Results layout ── */
.results-header { display: flex; align-items: center; justify-content: space-between; margin-bottom: 32px; padding: 40px 0 24px; border-bottom: 1px solid var(--slate-800); }
.doc-name { font-weight: 700; color: var(--white); font-size: 1.1rem; }
.results-meta { font-size: 0.85rem; color: var(--slate-400); }
.results-meta strong { color: var(--white); }
.results-section { margin-bottom: 36px; }
.results-section h3 { font-family: 'Syne', sans-serif; font-size: 1.2rem; font-weight: 800; color: var(--white); margin-bottom: 16px; display: flex; align-items: center; gap: 10px; }
.count { font-family: 'Plus Jakarta Sans', sans-serif; font-size: 0.75rem; font-weight: 700; background: var(--slate-800); padding: 2px 10px; border-radius: 100px; color: var(--slate-400); }

/* ── Executive Summary (markdown) ── */
.summary-text { background: var(--slate-900); border: 1px solid var(--slate-800); border-radius: 14px; padding: 24px; font-size: 0.95rem; line-height: 1.8; }
.summary-text h1,.summary-text h2,.summary-text h3,.summary-text h4,.summary-text h5,.summary-text h6 { font-family: 'Syne', sans-serif; font-weight: 800; color: var(--white); margin: 1.2em 0 0.5em; line-height: 1.3; }
.summary-text h1 { font-size: 1.4rem; }
.summary-text h2 { font-size: 1.2rem; }
.summary-text h3 { font-size: 1.05rem; }
.summary-text h4,.summary-text h5,.summary-text h6 { font-size: 0.95rem; font-family: 'Plus Jakarta Sans', sans-serif; font-weight: 700; }
.summary-text p { margin: 0 0 0.9em; }
.summary-text p:last-child { margin-bottom: 0; }
.summary-text strong,.summary-text b { color: var(--white); font-weight: 700; }
.summary-text em,.summary-text i { color: var(--slate-300); font-style: italic; }
.summary-text ul,.summary-text ol { margin: 0.5em 0 0.9em 1.4em; }
.summary-text li { margin-bottom: 0.3em; }
.summary-text li > ul,.summary-text li > ol { margin: 0.3em 0 0.3em 1.2em; }
.summary-text code { background: var(--slate-800); border: 1px solid var(--slate-700); border-radius: 4px; padding: 1px 6px; font-family: 'SF Mono', 'Fira Code', monospace; font-size: 0.85em; color: var(--amber-300); }
.summary-text pre { background: var(--slate-800); border: 1px solid var(--slate-700); border-radius: 8px; padding: 14px 16px; overflow-x: auto; margin: 0.8em 0; }
.summary-text pre code { background: none; border: none; padding: 0; color: var(--slate-300); font-size: 0.88em; }
.summary-text blockquote { border-left: 3px solid var(--amber-400); margin: 0.8em 0; padding: 8px 16px; background: rgba(245,183,49,0.04); border-radius: 0 8px 8px 0; }
.summary-text blockquote p { margin: 0; color: var(--slate-300); font-style: italic; }
.summary-text hr { border: none; border-top: 1px solid var(--slate-800); margin: 1em 0; }
.summary-text a { color: var(--amber-400); text-decoration: underline; }
.summary-text a:hover { color: var(--amber-300); }
.summary-text table { width: 100%; border-collapse: collapse; margin: 0.8em 0; font-size: 0.88rem; }
.summary-text th { background: var(--slate-800); color: var(--white); font-weight: 700; padding: 8px 12px; text-align: left; border: 1px solid var(--slate-700); }
.summary-text td { padding: 7px 12px; border: 1px solid var(--slate-800); color: var(--slate-300); }

/* ── Report Context Card ── */
.report-context-card { background: rgba(96,165,250,0.05); border: 1px solid rgba(96,165,250,0.2); border-left: 3px solid var(--blue-400); border-radius: 12px; padding: 20px 22px; margin-bottom: 36px; }
.report-context-card .rc-label { font-size: 0.7rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.08em; color: var(--blue-400); margin-bottom: 12px; display: flex; align-items: center; gap: 6px; }
.report-context-card .rc-label svg { width: 14px; height: 14px; }
.report-context-grid { display: grid; grid-template-columns: 1fr; gap: 10px; }
@media (min-width: 600px) { .report-context-grid { grid-template-columns: repeat(3, 1fr); } }
.rc-item-key { font-size: 0.72rem; font-weight: 600; color: var(--slate-400); margin-bottom: 3px; text-transform: uppercase; letter-spacing: 0.05em; }
.rc-item-val { font-size: 0.88rem; color: var(--slate-300); line-height: 1.5; }

/* ── Action Items ── */
.action-item { background: var(--slate-900); border: 1px solid var(--slate-800); border-radius: 12px; padding: 18px 20px; margin-bottom: 10px; display: flex; gap: 14px; }
.urgency-dot { width: 10px; height: 10px; border-radius: 50%; margin-top: 6px; flex-shrink: 0; }
.urgency-dot.immediate { background: var(--red-400); }
.urgency-dot.this_week { background: var(--amber-400); }
.urgency-dot.this_month { background: var(--blue-400); }
.action-content { flex: 1; }
.action-title { font-weight: 700; color: var(--white); font-size: 0.95rem; margin-bottom: 4px; }
.action-desc { font-size: 0.88rem; color: var(--slate-400); line-height: 1.6; }
.action-citation { font-size: 0.8rem; color: var(--slate-400); margin-top: 6px; padding: 6px 10px; background: rgba(245,183,49,0.05); border-left: 2px solid rgba(245,183,49,0.3); border-radius: 0 4px 4px 0; font-style: italic; line-height: 1.5; }
.action-citation::before { content: '📄 '; font-style: normal; }
.action-tags { display: flex; flex-wrap: wrap; gap: 6px; margin-top: 8px; }
.action-tag { padding: 2px 10px; border-radius: 6px; font-size: 0.72rem; font-weight: 600; text-transform: uppercase; }
.action-tag.immediate { background: rgba(248,113,113,0.1); color: var(--red-400); }
.action-tag.this_week { background: rgba(245,183,49,0.1); color: var(--amber-400); }
.action-tag.this_month { background: rgba(96,165,250,0.1); color: var(--blue-400); }
.action-tag.decision { background: rgba(192,132,252,0.1); color: var(--purple-400); }
.action-tag.task { background: rgba(74,222,128,0.1); color: var(--green-400); }
.action-tag.follow_up { background: rgba(96,165,250,0.1); color: var(--blue-400); }
.action-tag.risk_mitigation { background: rgba(248,113,113,0.1); color: var(--red-400); }
.action-tag.source-report { background: rgba(74,222,128,0.1); color: var(--green-400); }
.action-tag.source-ai { background: rgba(192,132,252,0.1); color: var(--purple-400); }

/* ── Decisions & Risks ── */
.decision-card, .risk-card { background: var(--slate-900); border: 1px solid var(--slate-800); border-radius: 12px; padding: 18px 20px; margin-bottom: 10px; }
.decision-card h4, .risk-card h4 { font-weight: 700; color: var(--white); font-size: 0.93rem; margin-bottom: 6px; }
.decision-card p, .risk-card p { font-size: 0.88rem; color: var(--slate-400); line-height: 1.6; }
.decision-deadline, .risk-mitigation { font-size: 0.82rem; font-weight: 600; color: var(--amber-400); margin-top: 6px; }
.risk-card { border-left: 3px solid var(--red-400); }

/* ── State pages ── */
.error-state { text-align: center; padding: 80px 0; }
.error-state h3 { color: var(--red-400); font-size: 1.2rem; margin-bottom: 8px; }
.access-denied-state { text-align: center; padding: 80px 0; }
.access-denied-state h3 { color: var(--amber-400); font-size: 1.2rem; margin-bottom: 8px; }
.access-denied-state p { color: var(--slate-400); margin-bottom: 24px; }

/* ── Buttons ── */
.btn { display: inline-flex; align-items: center; gap: 8px; padding: 14px 32px; border: none; border-radius: 10px; font-family: inherit; font-weight: 700; font-size: 0.95rem; cursor: pointer; transition: all 0.2s; text-decoration: none; }
.btn-primary { background: var(--amber-400); color: var(--slate-950); }
.btn-primary:hover { background: var(--amber-300); }
.email-btn { display: inline-flex; align-items: center; gap: 8px; padding: 10px 20px; background: var(--slate-800); color: var(--slate-300); border: 1px solid var(--slate-700); border-radius: 8px; font-family: inherit; font-size: 0.875rem; font-weight: 600; cursor: pointer; transition: all 0.2s; }
.email-btn:hover { background: var(--slate-700); color: var(--white); border-color: var(--slate-600); }
.email-btn:disabled { opacity: 0.5; cursor: not-allowed; }
.email-btn svg { width: 16px; height: 16px; }

/* ── Inline sharing toggle (single switch — shown in results header for owners) ── */
.results-actions { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; }
.reanalyze-btn {
    display: inline-flex; align-items: center; gap: 7px;
    padding: 9px 18px; background: var(--slate-800); color: var(--slate-300);
    border: 1px solid var(--slate-700); border-radius: 8px;
    font-family: inherit; font-size: 0.875rem; font-weight: 600;
    cursor: pointer; transition: all 0.2s; text-decoration: none;
}
.reanalyze-btn:hover { background: var(--slate-700); color: var(--white); border-color: var(--slate-600); }
.reanalyze-btn svg { width: 14px; height: 14px; }
.sharing-toggle { display: inline-flex; align-items: center; gap: 10px; }
.sharing-toggle-label { font-size: 0.72rem; font-weight: 700; color: var(--slate-400); text-transform: uppercase; letter-spacing: 0.07em; white-space: nowrap; }

/* Single toggle switch */
.toggle-switch { position: relative; display: inline-block; width: 44px; height: 24px; flex-shrink: 0; }
.toggle-switch input { opacity: 0; width: 0; height: 0; position: absolute; }
.toggle-slider { position: absolute; cursor: pointer; top: 0; left: 0; right: 0; bottom: 0; background: var(--slate-700); border: 1px solid var(--slate-600); border-radius: 24px; transition: background 0.2s, border-color 0.2s; }
.toggle-slider::before { content: ''; position: absolute; height: 18px; width: 18px; left: 2px; bottom: 2px; background: var(--slate-400); border-radius: 50%; transition: transform 0.2s, background 0.2s; }
.toggle-switch input:checked + .toggle-slider { background: rgba(74,222,128,0.2); border-color: var(--green-400); }
.toggle-switch input:checked + .toggle-slider::before { transform: translateX(20px); background: var(--green-400); }
.toggle-switch input:focus-visible + .toggle-slider { outline: 2px solid var(--amber-400); outline-offset: 2px; }

.toggle-status-text { font-size: 0.72rem; font-weight: 600; color: var(--slate-400); min-width: 42px; transition: color 0.15s; }
.toggle-status-text.public { color: var(--green-400); }

.copy-link-btn { display: inline-flex; align-items: center; gap: 5px; padding: 5px 12px; background: var(--slate-800); color: var(--slate-300); border: 1px solid var(--slate-700); border-radius: 8px; font-family: inherit; font-size: 0.75rem; font-weight: 600; cursor: pointer; transition: all 0.2s; white-space: nowrap; }
.copy-link-btn:hover { background: var(--slate-700); color: var(--white); }
.copy-link-btn.copied { color: var(--green-400); border-color: var(--green-400); }

/* ── Sharing & Access section ── */
.sharing-section { background: var(--slate-900); border: 1px solid var(--slate-700); border-radius: 14px; padding: 20px 22px; margin-bottom: 36px; }
.sharing-header { display: flex; align-items: center; gap: 8px; font-family: 'Syne', sans-serif; font-size: 0.85rem; font-weight: 800; color: var(--white); text-transform: uppercase; letter-spacing: 0.06em; margin-bottom: 18px; }
.sharing-header svg { width: 16px; height: 16px; color: var(--amber-400); flex-shrink: 0; }
.sharing-status-row { display: flex; align-items: center; gap: 8px; margin-bottom: 14px; }
.sharing-status-badge { font-size: 0.82rem; font-weight: 700; padding: 4px 10px; border-radius: 6px; }
.sharing-status-badge[data-status='public'] { background: rgba(74,222,128,0.1); color: var(--green-400); }
.sharing-status-badge[data-status='private'] { background: var(--slate-800); color: var(--slate-400); }
.sharing-status-desc { font-size: 0.82rem; color: var(--slate-400); }
.sharing-actions { display: flex; flex-wrap: wrap; gap: 10px; margin-bottom: 14px; align-items: center; }
.sharing-empty-hint { font-size: 0.8rem; color: var(--slate-400); text-align: center; padding: 8px 0; }

/* ── Toast notifications ── */
.toast { position: fixed; bottom: 24px; right: 24px; padding: 14px 20px; border-radius: 10px; font-size: 0.875rem; font-weight: 600; display: flex; align-items: center; gap: 10px; z-index: 9999; transform: translateY(80px); opacity: 0; transition: all 0.3s cubic-bezier(0.34, 1.56, 0.64, 1); pointer-events: none; max-width: 320px; }
.toast.show { transform: translateY(0); opacity: 1; }
.toast-success { background: #1a2e1a; border: 1px solid var(--green-400); color: var(--green-400); }
.toast-error { background: #2e1a1a; border: 1px solid var(--red-400); color: var(--red-400); }

/* ── Dig Deeper ── */
.dig-deeper-btn { display: inline-flex; align-items: center; gap: 5px; margin-top: 8px; padding: 3px 0; background: none; border: none; cursor: pointer; font-family: inherit; font-size: 0.78rem; font-weight: 600; color: var(--slate-400); transition: color 0.15s; letter-spacing: 0.01em; }
.dig-deeper-btn:hover { color: var(--amber-400); }
.dig-deeper-btn.open { color: var(--amber-400); }
.dig-deeper-btn svg { width: 12px; height: 12px; transition: transform 0.2s; }
.dig-deeper-btn.open svg { transform: rotate(180deg); }
@media (min-width: 640px) { .dig-deeper-btn { opacity: 0; } .action-item:hover .dig-deeper-btn, .decision-card:hover .dig-deeper-btn, .risk-card:hover .dig-deeper-btn, .dig-deeper-btn.open { opacity: 1; } }
.dig-deeper-panel { display: none; margin-top: 12px; border-left: 3px solid var(--amber-400); border-radius: 0 10px 10px 0; background: rgba(245,183,49,0.04); padding: 16px 18px; }
.dig-deeper-panel.open { display: block; }
.dd-loading { display: flex; align-items: center; gap: 10px; font-size: 0.82rem; color: var(--slate-400); padding: 4px 0; }
.dd-spinner { width: 14px; height: 14px; border: 2px solid var(--slate-700); border-top-color: var(--amber-400); border-radius: 50%; animation: spin 0.8s linear infinite; flex-shrink: 0; }
.dd-section { margin-bottom: 14px; }
.dd-section:last-child { margin-bottom: 0; }
.dd-label { font-size: 0.68rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.09em; color: var(--amber-400); margin-bottom: 6px; }
.dd-content { font-size: 0.85rem; color: var(--slate-300); line-height: 1.65; }
.dd-quote { font-style: italic; padding: 6px 10px; background: rgba(255,255,255,0.03); border-left: 2px solid var(--slate-700); border-radius: 0 4px 4px 0; margin-bottom: 6px; font-size: 0.82rem; color: var(--slate-400); }
.dd-quote:last-child { margin-bottom: 0; }
.dd-ai-badge { display: inline-flex; align-items: center; gap: 4px; font-size: 0.65rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.07em; color: var(--purple-400); background: rgba(192,132,252,0.08); padding: 1px 6px; border-radius: 4px; margin-bottom: 5px; }
.dd-error { font-size: 0.82rem; color: var(--red-400); }

/* ── Footer ── */
footer { padding: 48px 0; text-align: center; border-top: 1px solid var(--slate-800); margin-top: 40px; }
footer p { font-size: 0.85rem; color: var(--slate-400); }