/* Parameter Risk Score — /risk page styles
   Token system mirrors PARAMETER.md and page-parameter-audit.php conventions. */

.prisk {
    --p-brand: #7A5AF8;
    --p-brand-700: #6B46F2;
    --p-brand-900: #4E2DE3;
    --p-accent: #00C2A8;
    --p-text: #0F172A;
    --p-muted: #475569;
    --p-soft: #F6F7FF;
    --p-border: #E5E7EB;
    --p-radius: 16px;
    --p-radius-btn: 10px;
    --p-shadow: 0 12px 40px rgba(15, 23, 42, 0.08);
    --p-container: 1180px;

    --grade-a: #16a34a;
    --grade-b: #65a30d;
    --grade-c: #d97706;
    --grade-d: #ea580c;
    --grade-f: #dc2626;

    color: var(--p-text);
    font-family: "Space Grotesk", system-ui, -apple-system, "Segoe UI", sans-serif;
    line-height: 1.6;
}

.prisk *, .prisk *::before, .prisk *::after { box-sizing: border-box; }

.prisk__container { max-width: var(--p-container); margin: 0 auto; padding: 0 24px; }

.prisk__hero,
.prisk__scanning,
.prisk__results { padding: 72px 0; position: relative; }

.prisk__scanning { background: var(--p-soft); }

/* Center the constrained-width inner blocks on the hero + scanning sections so
   they don't sit flush left inside the wide 1180px container (the leftover
   right gap was the symptom). Results section keeps its existing left-aligned
   data-card layout — only hero + scanning get this treatment. */
.prisk__hero .prisk__container,
.prisk__scanning .prisk__container {
    text-align: center;
    display: flex;
    flex-direction: column;
    align-items: center;
}
.prisk__hero .prisk__h1,
.prisk__hero .prisk__lead,
.prisk__hero .prisk__form,
.prisk__scanning .prisk__h2,
.prisk__scanning .prisk__lead,
.prisk__scanning .prisk__loader-bar,
.prisk__scanning .prisk__progress {
    margin-left: auto;
    margin-right: auto;
}
/* Form contents (label + input row) read more naturally left-aligned even when
   the form card itself is centered. */
.prisk__hero .prisk__form { text-align: left; }
.prisk__scanning .prisk__progress li { text-align: left; }

.prisk__brand {
    font-size: 1.1rem;
    font-weight: 800;
    letter-spacing: -0.01em;
    color: var(--p-brand-900);
    margin: 0 0 12px;
    line-height: 1;
}

.prisk__eyebrow {
    display: inline-block;
    font-size: 12px;
    font-weight: 600;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--p-brand-900);
    background: rgba(122, 90, 248, 0.08);
    border: 1px solid rgba(122, 90, 248, 0.22);
    padding: 6px 12px;
    border-radius: 999px;
    margin: 0 0 20px;
}

.prisk__h1 {
    font-size: clamp(2rem, 4vw, 3.25rem);
    font-weight: 700;
    line-height: 1.1;
    letter-spacing: -0.02em;
    margin: 0 0 16px;
    max-width: 22ch;
}

.prisk__h2 {
    font-size: clamp(1.5rem, 3vw, 2rem);
    font-weight: 700;
    line-height: 1.15;
    letter-spacing: -0.02em;
    margin: 0 0 16px;
}

.prisk__lead {
    font-size: 1.15rem;
    color: var(--p-muted);
    line-height: 1.65;
    max-width: 65ch;
    margin: 0 0 32px;
}

.prisk__form {
    background: #fff;
    border: 1px solid var(--p-border);
    border-radius: var(--p-radius);
    box-shadow: var(--p-shadow);
    padding: 28px;
    max-width: 720px;
}

.prisk__label {
    display: block;
    font-size: 13px;
    font-weight: 600;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    color: var(--p-muted);
    margin: 0 0 10px;
}

.prisk__input-row {
    display: grid;
    grid-template-columns: 1fr auto;
    gap: 12px;
    align-items: stretch;
}

.prisk__input {
    font: inherit;
    font-size: 16px;
    padding: 14px 16px;
    border: 1px solid var(--p-border);
    border-radius: var(--p-radius-btn);
    background: #fff;
    color: var(--p-text);
    width: 100%;
    transition: border-color .15s ease, box-shadow .15s ease;
}

.prisk__input:focus {
    outline: none;
    border-color: var(--p-brand);
    box-shadow: 0 0 0 3px rgba(122, 90, 248, 0.18);
}

.prisk__btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    padding: 14px 22px;
    border-radius: var(--p-radius-btn);
    text-decoration: none;
    font: inherit;
    font-weight: 700;
    font-size: 0.95rem;
    border: 1px solid transparent;
    cursor: pointer;
    min-height: 48px;
    transition: background .15s ease, border-color .15s ease, color .15s ease, box-shadow .15s ease, transform .15s ease;
}

.prisk__btn--primary {
    background: linear-gradient(135deg, var(--p-brand-900), var(--p-brand));
    color: #fff;
    box-shadow: 0 8px 24px rgba(78, 45, 227, 0.25);
}
.prisk__btn--primary:hover { transform: translateY(-1px); box-shadow: 0 12px 28px rgba(78, 45, 227, 0.30); }
.prisk__btn--primary:disabled { opacity: 0.6; cursor: not-allowed; transform: none; }

.prisk__btn--ghost {
    background: #fff;
    color: var(--p-brand-900);
    border-color: rgba(78, 45, 227, 0.22);
}
.prisk__btn--ghost:hover { border-color: var(--p-brand); background: rgba(122, 90, 248, 0.06); }

.prisk__micro {
    font-size: 13px;
    color: var(--p-muted);
    margin: 14px 0 0;
}
.prisk__micro--note {
    font-style: italic;
    margin-top: 6px;
}

/* Subtle info callout — used for the "non-invasive / not a penetration test"
   framing line so it reads as a deliberate disclosure rather than fine print. */
.prisk__notice {
    display: flex;
    align-items: flex-start;
    gap: 10px;
    margin: 14px 0 0;
    padding: 12px 14px;
    background: rgba(122, 90, 248, 0.05);
    border: 1px solid rgba(122, 90, 248, 0.18);
    border-radius: 10px;
    color: var(--p-text);
    font-size: 12.5px;
    line-height: 1.5;
    text-align: left;
}
.prisk__notice-icon {
    flex-shrink: 0;
    width: 18px;
    height: 18px;
    color: var(--p-brand-900);
    margin-top: 1px;
}
.prisk__notice-icon svg { width: 18px; height: 18px; display: block; }
.prisk__notice-text { color: var(--p-muted); }

.prisk__micro--legal {
    margin-top: 10px;
    font-size: 11px;
    color: var(--p-muted);
}
.prisk__micro--legal a { color: var(--p-brand-900); }
.prisk__micro--legal a:hover { color: var(--p-brand); }

.prisk__error {
    margin: 14px 0 0;
    padding: 12px 14px;
    border-radius: 10px;
    background: rgba(220, 38, 38, 0.08);
    border: 1px solid rgba(220, 38, 38, 0.22);
    color: #b91c1c;
    font-size: 0.95rem;
    font-weight: 600;
}

/* Scanning loader -------------------------------------------------------- */

.prisk__loader-bar {
    position: relative;
    width: 100%;
    max-width: 560px;
    height: 8px;
    background: rgba(122, 90, 248, 0.10);
    border-radius: 999px;
    overflow: hidden;
    margin: 24px 0 8px;
}
.prisk__loader-bar-fill {
    position: absolute;
    top: 0;
    left: 0;
    height: 100%;
    width: 35%;
    border-radius: inherit;
    background: linear-gradient(90deg, var(--p-brand-900), var(--p-brand), var(--p-brand-900));
    background-size: 200% 100%;
    animation: prisk-bar-slide 1.4s ease-in-out infinite, prisk-bar-shimmer 1.8s linear infinite;
}
@keyframes prisk-bar-slide {
    0%   { left: -40%;  width: 35%; }
    50%  { left: 30%;   width: 55%; }
    100% { left: 100%;  width: 35%; }
}
@keyframes prisk-bar-shimmer {
    0%   { background-position:   0% 0; }
    100% { background-position: 200% 0; }
}

.prisk__progress {
    list-style: none;
    margin: 24px 0 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 10px;
    max-width: 560px;
}

.prisk__progress li {
    display: grid;
    grid-template-columns: 24px 1fr auto;
    align-items: center;
    gap: 14px;
    padding: 14px 18px;
    background: #fff;
    border: 1px solid var(--p-border);
    border-radius: 12px;
    font-weight: 600;
    color: var(--p-text);
}
.prisk__progress li[data-status="pending"] { color: var(--p-muted); }
.prisk__progress li[data-status="running"] { border-color: var(--p-brand); box-shadow: 0 0 0 3px rgba(122, 90, 248, 0.10); }
.prisk__progress li[data-status="done"] { color: var(--p-text); }

.prisk__progress-dot {
    display: inline-block;
    width: 16px;
    height: 16px;
    border-radius: 50%;
    background: var(--p-border);
}
.prisk__progress li[data-status="running"] .prisk__progress-dot {
    background: var(--p-brand);
    animation: prisk-pulse 1s ease-in-out infinite;
}
.prisk__progress li[data-status="done"] .prisk__progress-dot {
    background: #16a34a;
}
.prisk__progress-status {
    font-size: 12px;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--p-muted);
}
.prisk__progress li[data-status="done"] .prisk__progress-status { color: #16a34a; }
.prisk__progress li[data-status="running"] .prisk__progress-status { color: var(--p-brand-900); }

@keyframes prisk-pulse {
    0%, 100% { opacity: 1; transform: scale(1); }
    50% { opacity: 0.55; transform: scale(0.85); }
}

/* Results ---------------------------------------------------------------- */

.prisk__score-card {
    display: grid;
    grid-template-columns: 1fr auto;
    grid-template-areas:
        "meta    grade"
        "score   grade"
        "verdict verdict"
        "cached  cached"
        "phase   phase";
    gap: 18px 24px;
    align-items: center;
    background: #fff;
    border: 1px solid var(--p-border);
    border-radius: var(--p-radius);
    box-shadow: var(--p-shadow);
    padding: 32px;
    margin: 0 0 32px;
    position: relative;
    overflow: hidden;
}
.prisk__score-card::before {
    content: '';
    position: absolute;
    left: 0; right: 0; top: 0;
    height: 4px;
    background: linear-gradient(90deg, var(--p-brand-900), var(--p-brand));
}

.prisk__score-meta { grid-area: meta; }
.prisk__score-meta .prisk__eyebrow { margin-bottom: 6px; }

.prisk__host {
    margin: 0;
    font-weight: 700;
    color: var(--p-text);
    word-break: normal;
    overflow-wrap: anywhere;
}

.prisk__score-big {
    grid-area: score;
    display: flex;
    align-items: baseline;
    gap: 8px;
}
.prisk__score-num {
    font-size: clamp(3rem, 8vw, 5rem);
    font-weight: 800;
    line-height: 1;
    letter-spacing: -0.04em;
    color: var(--p-text);
}
.prisk__score-out {
    font-size: 1.25rem;
    color: var(--p-muted);
    font-weight: 600;
}

.prisk__grade-chip {
    grid-area: grade;
    width: 88px;
    height: 88px;
    border-radius: 22px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 3rem;
    font-weight: 800;
    color: #fff;
    background: var(--grade-c);
    box-shadow: 0 8px 24px rgba(15, 23, 42, 0.12);
    justify-self: end;
}
.prisk__grade-chip[data-grade="A"] { background: var(--grade-a); }
.prisk__grade-chip[data-grade="B"] { background: var(--grade-b); }
.prisk__grade-chip[data-grade="C"] { background: var(--grade-c); }
.prisk__grade-chip[data-grade="D"] { background: var(--grade-d); }
.prisk__grade-chip[data-grade="F"] { background: var(--grade-f); }

.prisk__verdict {
    grid-area: verdict;
    margin: 0;
    font-size: 1.1rem;
    color: var(--p-text);
    font-weight: 600;
}

.prisk__score-actions {
    grid-area: actions;
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    margin: 6px 0 0;
    align-items: stretch;
}

.prisk__cached {
    grid-area: cached;
    margin: 0;
    font-size: 13px;
    color: var(--p-muted);
}

.prisk__phase-note {
    grid-area: phase;
    margin: 0;
    font-size: 13px;
    background: rgba(217, 119, 6, 0.08);
    border: 1px solid rgba(217, 119, 6, 0.25);
    color: #92400e;
    padding: 10px 14px;
    border-radius: 10px;
    font-weight: 600;
}

.prisk__notes {
    list-style: none;
    margin: 0 0 24px;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 8px;
}
.prisk__note {
    display: grid;
    grid-template-columns: 24px 1fr;
    align-items: start;
    gap: 12px;
    padding: 12px 16px;
    background: rgba(59, 130, 246, 0.06);
    border: 1px solid rgba(59, 130, 246, 0.20);
    border-radius: 12px;
    color: var(--p-text);
    font-size: 0.92rem;
    line-height: 1.55;
}
.prisk__note-icon {
    width: 22px;
    height: 22px;
    border-radius: 50%;
    background: #2563eb;
    color: #fff;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-weight: 800;
    font-style: italic;
    font-family: serif;
    font-size: 14px;
}

.prisk__detection {
    background: #fff;
    border: 1px solid var(--p-border);
    border-radius: var(--p-radius);
    box-shadow: var(--p-shadow);
    padding: 28px;
    margin: 0 0 32px;
}
.prisk__detection-head { margin: 0 0 18px; }
.prisk__detection-head .prisk__eyebrow { margin-bottom: 8px; }
.prisk__h3 {
    font-size: 1.25rem;
    font-weight: 700;
    letter-spacing: -0.015em;
    margin: 0;
}
.prisk__detection-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
    gap: 16px;
    margin: 0 0 18px;
}
.prisk__detection-grid > div {
    background: var(--p-soft);
    border: 1px solid var(--p-border);
    border-radius: 12px;
    padding: 14px 16px;
}
.prisk__detection-grid dt {
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--p-muted);
    margin: 0 0 4px;
}
.prisk__detection-grid dd {
    margin: 0;
    font-weight: 700;
    color: var(--p-text);
    word-break: normal;
    overflow-wrap: anywhere;
}
.prisk__eyebrow--mini {
    font-size: 11px;
    margin: 0 0 10px;
    padding: 4px 10px;
}
.prisk__detection-plugins ul {
    margin: 0;
    padding: 0;
    list-style: none;
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}
.prisk__detection-plugins li {
    background: rgba(122, 90, 248, 0.06);
    border: 1px solid rgba(122, 90, 248, 0.18);
    color: var(--p-brand-900);
    padding: 6px 12px;
    border-radius: 999px;
    font-size: 13px;
    font-weight: 600;
    font-variant-numeric: tabular-nums;
}
.prisk__detection-note {
    margin: 16px 0 0;
    font-size: 12px;
    color: var(--p-muted);
    line-height: 1.55;
}

.prisk__categories {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: 16px;
    margin: 0 0 32px;
}

.prisk__cat {
    background: #fff;
    border: 1px solid var(--p-border);
    border-radius: var(--p-radius);
    box-shadow: var(--p-shadow);
    padding: 24px;
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.prisk__cat-head {
    display: flex;
    align-items: baseline;
    justify-content: space-between;
    gap: 12px;
}
.prisk__cat-label {
    font-size: 12px;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--p-muted);
    margin: 0;
}
.prisk__cat-score {
    font-size: 1.5rem;
    font-weight: 800;
    color: var(--p-text);
    letter-spacing: -0.02em;
}
.prisk__cat-title {
    margin: 0;
    font-size: 1.1rem;
    font-weight: 700;
    letter-spacing: -0.01em;
}
.prisk__cat-summary {
    margin: 0;
    color: var(--p-muted);
    font-size: 0.95rem;
    line-height: 1.55;
}
.prisk__cat-bar {
    height: 6px;
    border-radius: 999px;
    background: var(--p-border);
    overflow: hidden;
    margin: 4px 0 0;
}
.prisk__cat-bar > span {
    display: block;
    height: 100%;
    background: linear-gradient(90deg, var(--p-brand-900), var(--p-brand));
    border-radius: inherit;
}

/* Expandable category details */
.prisk__cat-toggle {
    margin: 14px 0 0;
    background: transparent;
    border: 0;
    padding: 8px 0 0;
    color: var(--p-brand-900);
    font: inherit;
    font-size: 0.9rem;
    font-weight: 700;
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    gap: 6px;
    align-self: flex-start;
}
.prisk__cat-toggle:hover { color: var(--p-brand); }
.prisk__cat-toggle:hover .prisk__cat-toggle-icon { transform: translateX(2px); }
.prisk__cat-toggle-icon { transition: transform .15s ease; display: inline-block; }

/* Modal --------------------------------------------------------------- */

.prisk__modal {
    position: fixed;
    inset: 0;
    z-index: 9999;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 24px;
    font-family: "Space Grotesk", system-ui, -apple-system, sans-serif;
    color: var(--p-text);
}
.prisk__modal[hidden] { display: none; }
body.prisk-modal-open { overflow: hidden; }

.prisk__modal-backdrop {
    position: absolute;
    inset: 0;
    background: rgba(11, 18, 32, 0.55);
    backdrop-filter: blur(2px);
    animation: prisk-fade-in .15s ease;
}
.prisk__modal-card {
    position: relative;
    background: #fff;
    border-radius: var(--p-radius);
    box-shadow: 0 30px 80px rgba(11, 18, 32, 0.30);
    max-width: 720px;
    width: 100%;
    max-height: calc(100vh - 48px);
    overflow: hidden;
    display: flex;
    flex-direction: column;
    animation: prisk-modal-in .18s ease;
}
@keyframes prisk-fade-in { from {opacity:0;} to {opacity:1;} }
@keyframes prisk-modal-in {
    from { opacity: 0; transform: translateY(12px) scale(.98); }
    to   { opacity: 1; transform: translateY(0)    scale(1); }
}

.prisk__modal-close {
    position: absolute;
    top: 16px;
    right: 16px;
    width: 44px;
    height: 44px;
    border: 1px solid var(--p-border);
    background: rgba(255,255,255,.95);
    color: var(--p-text);
    border-radius: 12px;
    font-size: 22px;
    line-height: 1;
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    z-index: 2;
    transition: background .15s ease, border-color .15s ease;
}
.prisk__modal-close:hover { background: var(--p-soft); border-color: var(--p-brand); color: var(--p-brand-900); }

.prisk__modal-head {
    padding: 32px 32px 18px;
    border-bottom: 1px solid var(--p-border);
    background: linear-gradient(180deg, rgba(122,90,248,0.04), rgba(122,90,248,0));
}
.prisk__modal-head .prisk__eyebrow { margin-bottom: 8px; }
.prisk__modal-head .prisk__h2 { margin: 0 0 6px; }
.prisk__modal-score {
    display: flex;
    align-items: baseline;
    gap: 6px;
    margin: 12px 0 8px;
}
.prisk__modal-score-num {
    font-size: 2rem;
    font-weight: 800;
    line-height: 1;
    letter-spacing: -0.03em;
}
.prisk__modal-score-out {
    font-size: 0.95rem;
    color: var(--p-muted);
    font-weight: 600;
}
.prisk__modal-summary {
    margin: 0;
    color: var(--p-text);
    font-size: 1rem;
    line-height: 1.55;
}

.prisk__modal-body {
    padding: 24px 32px 32px;
    overflow-y: auto;
    display: flex;
    flex-direction: column;
    gap: 20px;
}

@media (max-width: 640px) {
    .prisk__modal { padding: 0; }
    .prisk__modal-card { border-radius: 0; max-height: 100vh; height: 100vh; }
    .prisk__modal-head, .prisk__modal-body { padding-left: 20px; padding-right: 20px; }
}

/* Plugin-match cards inside the modal */
.prisk__match-list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 12px;
}
.prisk__match {
    background: var(--p-soft);
    border: 1px solid var(--p-border);
    border-radius: 12px;
    padding: 14px 16px;
}
.prisk__match[data-severity="critical"] { background: rgba(220,38,38,.06); border-color: rgba(220,38,38,.22); }
.prisk__match[data-severity="high"]     { background: rgba(234,88,12,.06);  border-color: rgba(234,88,12,.22); }
.prisk__match[data-severity="medium"]   { background: rgba(217,119,6,.06);  border-color: rgba(217,119,6,.22); }
.prisk__match-head {
    display: flex;
    align-items: center;
    gap: 10px;
    flex-wrap: wrap;
    margin: 0 0 8px;
    font-size: 1rem;
}
.prisk__match-cve {
    font-family: ui-monospace, "SF Mono", Menlo, monospace;
    font-size: 12px;
    color: var(--p-muted);
}
.prisk__match-meta {
    display: flex;
    gap: 16px;
    flex-wrap: wrap;
    margin: 0 0 10px;
}
.prisk__match-meta div { display: inline-flex; flex-direction: column; gap: 2px; }
.prisk__match-meta dt {
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--p-muted);
    margin: 0;
}
.prisk__match-meta dd { margin: 0; font-size: 13px; font-weight: 700; color: var(--p-text); font-family: ui-monospace, "SF Mono", Menlo, monospace; }
.prisk__match-summary { margin: 0; font-size: 0.92rem; line-height: 1.55; color: var(--p-text); }

/* Header inventory & similar grids — bump warn state for perf metrics */
.prisk__hdr-row[data-ok="warn"] {
    background: rgba(245, 158, 11, 0.08);
    border-color: rgba(245, 158, 11, 0.24);
}
.prisk__hdr-row[data-ok="warn"] .prisk__hdr-mark { background: #d97706; }
.prisk__hdr-row[data-ok="warn"] .prisk__hdr-state { color: #92400e; }
.prisk__cat-section { display: flex; flex-direction: column; gap: 10px; }
.prisk__cat-subhead {
    margin: 0;
    font-size: 12px;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--p-muted);
}

.prisk__finding-list, .prisk__rec-list {
    margin: 0;
    padding: 0;
    list-style: none;
    display: flex;
    flex-direction: column;
    gap: 8px;
}
.prisk__rec-list { padding-left: 22px; list-style: decimal; color: var(--p-text); }
.prisk__rec-list li { font-size: 0.92rem; line-height: 1.55; }

.prisk__finding {
    display: grid;
    grid-template-columns: auto 1fr;
    gap: 10px;
    align-items: start;
    padding: 10px 12px;
    background: var(--p-soft);
    border: 1px solid var(--p-border);
    border-radius: 10px;
    font-size: 0.92rem;
    line-height: 1.5;
}
.prisk__finding-msg { color: var(--p-text); }
.prisk__sev-pill {
    display: inline-block;
    padding: 2px 8px;
    border-radius: 999px;
    font-size: 10px;
    font-weight: 800;
    letter-spacing: 0.08em;
    background: rgba(15, 23, 42, 0.10);
    color: var(--p-muted);
    align-self: center;
    min-width: 56px;
    text-align: center;
}
.prisk__sev-pill[data-severity="info"]     { background: rgba(59, 130, 246, 0.14); color: #1d4ed8; }
.prisk__sev-pill[data-severity="low"]      { background: rgba(245, 158, 11, 0.16); color: #b45309; }
.prisk__sev-pill[data-severity="medium"]   { background: rgba(217, 119, 6, 0.18);  color: #92400e; }
.prisk__sev-pill[data-severity="high"]     { background: rgba(234, 88, 12, 0.18);  color: #9a3412; }
.prisk__sev-pill[data-severity="critical"] { background: rgba(220, 38, 38, 0.18);  color: #b91c1c; }

/* Header inventory grid (security_headers detail) */
.prisk__hdr-grid {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 6px;
}
.prisk__hdr-row {
    display: grid;
    grid-template-columns: 24px 1fr auto;
    align-items: center;
    gap: 10px;
    padding: 10px 12px;
    background: var(--p-soft);
    border: 1px solid var(--p-border);
    border-radius: 10px;
    font-size: 0.9rem;
}
.prisk__hdr-row[data-ok="1"] { background: rgba(22, 163, 74, 0.08); border-color: rgba(22, 163, 74, 0.22); }
.prisk__hdr-row[data-ok="0"] { background: rgba(220, 38, 38, 0.06); border-color: rgba(220, 38, 38, 0.20); }

.prisk__hdr-mark {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 22px;
    height: 22px;
    border-radius: 50%;
    font-weight: 800;
    font-size: 14px;
    color: #fff;
}
.prisk__hdr-row[data-ok="1"] .prisk__hdr-mark { background: #16a34a; }
.prisk__hdr-row[data-ok="0"] .prisk__hdr-mark { background: #dc2626; }

.prisk__hdr-name { font-weight: 700; color: var(--p-text); font-family: ui-monospace, "SF Mono", Menlo, monospace; font-size: 0.85rem; }
.prisk__hdr-state {
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: var(--p-muted);
}
.prisk__hdr-row[data-ok="1"] .prisk__hdr-state { color: #15803d; }
.prisk__hdr-row[data-ok="0"] .prisk__hdr-state { color: #b91c1c; }

.prisk__hdr-leak {
    margin: 12px 0 0;
    padding: 10px 12px;
    background: rgba(245, 158, 11, 0.08);
    border: 1px solid rgba(245, 158, 11, 0.24);
    color: #92400e;
    border-radius: 10px;
    font-size: 12px;
    font-family: ui-monospace, "SF Mono", Menlo, monospace;
    word-break: break-all;
}

.prisk__cat { display: flex; flex-direction: column; }

.prisk__rescan { margin: 0 0 24px; }

.prisk__disclosure {
    font-size: 13px;
    color: var(--p-muted);
    border-top: 1px solid var(--p-border);
    padding-top: 18px;
    max-width: 720px;
    line-height: 1.6;
}

/* Mobile ----------------------------------------------------------------- */

@media (max-width: 640px) {
    .prisk__hero,
    .prisk__scanning,
    .prisk__results { padding: 48px 0; }
    .prisk__form { padding: 22px; }
    .prisk__input-row { grid-template-columns: 1fr; }
    .prisk__btn { width: 100%; }

    .prisk__score-card {
        grid-template-columns: 1fr auto;
        grid-template-areas:
            "meta    grade"
            "score   grade"
            "verdict verdict"
            "cached  cached"
            "phase   phase";
    }
    .prisk__grade-chip { width: 72px; height: 72px; font-size: 2.4rem; border-radius: 18px; }
}

/* CTA row directly below score card — buttons smooth-scroll to the anchored
   PDF + audit cards that sit below the rest of the report. */
.prisk__cta-row {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    margin: 0 0 32px;
}
.prisk__cta-row .prisk__btn { flex: 1 1 220px; text-align: center; justify-content: center; }
@media (max-width: 640px) {
    .prisk__cta-row { flex-direction: column; }
    .prisk__cta-row .prisk__btn { width: 100%; flex: 1 1 auto; }
}

/* Conversion cards live below the report (categories) and are anchored. */
.prisk__cards-below {
    display: grid;
    gap: 22px;
    margin: 32px 0;
    grid-template-columns: 1fr;
}
@media (min-width: 880px) {
    .prisk__cards-below { grid-template-columns: 1fr 1fr; align-items: stretch; }
}
#prisk-pdf-card,
#prisk-audit-card {
    /* keep the smooth-scroll target clear of any sticky chrome */
    scroll-margin-top: 24px;
}
.prisk__block {
    background: #fff;
    border: 1px solid var(--p-border);
    border-radius: var(--p-radius);
    padding: 26px;
    box-shadow: var(--p-shadow);
    position: relative;
    display: flex;
    flex-direction: column;
}
.prisk__block .prisk__h3 {
    font-size: 1.15rem;
    font-weight: 700;
    margin: 0 0 8px;
    color: var(--p-text);
    letter-spacing: -0.01em;
}
.prisk__email-lead,
.prisk__assess-lead {
    color: var(--p-muted);
    font-size: 0.95rem;
    margin: 0 0 16px;
    line-height: 1.6;
}

/* Email gate form */
.prisk__email-form { display: flex; flex-direction: column; gap: 12px; }
.prisk__field { display: flex; flex-direction: column; gap: 6px; }
.prisk__field span {
    font-size: 12px;
    font-weight: 700;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    color: var(--p-muted);
}
.prisk__field span em { font-style: normal; opacity: 0.7; text-transform: none; letter-spacing: 0; font-weight: 600; }
.prisk__field input {
    font: inherit;
    font-size: 16px;
    padding: 12px 14px;
    border: 1px solid var(--p-border);
    border-radius: 10px;
    background: #fff;
    color: var(--p-text);
}
.prisk__field input:focus {
    outline: none;
    border-color: var(--p-brand);
    box-shadow: 0 0 0 3px rgba(122, 90, 248, 0.18);
}
.prisk__error {
    margin: 0;
    padding: 10px 12px;
    background: rgba(220, 38, 38, 0.08);
    border: 1px solid rgba(220, 38, 38, 0.22);
    color: #b91c1c;
    border-radius: 10px;
    font-size: 0.9rem;
    font-weight: 600;
}
.prisk__email-thanks {
    background: rgba(22, 163, 74, 0.06);
    border: 1px solid rgba(22, 163, 74, 0.22);
    border-radius: var(--p-radius);
    padding: 22px;
    margin-top: 4px;
}
.prisk__email-thanks p { margin: 8px 0 0; color: var(--p-text); font-size: 0.95rem; }

