
/* ThreatGrid Pro portal */
.pro-shell { padding: 1.5rem 0 2rem; }
.pro-subheader {
    position: sticky;
    top: 78px;
    z-index: 40;
    border-bottom: 1px solid var(--line);
    background: rgba(7,17,31,.9);
    backdrop-filter: blur(18px);
}
[data-theme="light"] .pro-subheader { background: rgba(255,255,255,.92); }
.pro-subheader-inner {
    min-height: 68px;
    display: grid;
    grid-template-columns: auto 1fr auto;
    gap: 1rem;
    align-items: center;
}
.pro-brand { display:inline-flex; align-items:center; gap:.8rem; }
.pro-brand-mark {
    width:42px; height:42px; border-radius:14px; display:grid; place-items:center;
    font-weight:800; color:#fff; background:linear-gradient(135deg,var(--primary), var(--tools)); box-shadow: var(--shadow);
}
.pro-brand-copy strong { display:block; line-height:1.1; }
.pro-brand-copy span { display:block; color:var(--muted); font-size:.76rem; line-height:1.2; }
.pro-subnav, .pro-subheader-actions { display:flex; gap:.6rem; flex-wrap:wrap; align-items:center; }
.pro-subnav a, .pro-subheader-actions a {
    display:inline-flex; align-items:center; min-height:40px; padding:.65rem .9rem; border-radius:12px;
    border:1px solid transparent; color:var(--muted); text-decoration:none; font-weight:700;
}
.pro-subnav a:hover, .pro-subnav a.is-active, .pro-subheader-actions a:hover {
    color:var(--text); background:rgba(255,255,255,.05); border-color:var(--line);
}
.pro-layout { display:grid; grid-template-columns: 280px minmax(0,1fr); gap:1.25rem; align-items:start; }
.pro-sidebar, .pro-card, .pro-stat-card { background:var(--panel); border:1px solid var(--line); border-radius:24px; box-shadow: var(--shadow); }
.pro-sidebar { padding:1rem; position:sticky; top:calc(78px + 68px + 1rem); display:grid; gap:.9rem; }
.pro-main { min-width:0; display:grid; gap:1.25rem; }
.pro-hero {
    padding:1.5rem; border-radius:24px; border:1px solid var(--line); box-shadow:var(--shadow);
    background: radial-gradient(circle at top right, rgba(181,110,255,.16), transparent 36%), radial-gradient(circle at left top, rgba(26,115,232,.14), transparent 24%), var(--panel);
}
.pro-hero .eyebrow { margin-bottom:.85rem; }
.pro-hero h1 { margin:0 0 .85rem; font-size: clamp(2rem, 4vw, 3rem); line-height:1.04; }
.pro-hero p { max-width:68ch; }
.pro-hero-actions { display:flex; gap:.75rem; flex-wrap:wrap; }
.pro-stats-grid { display:grid; grid-template-columns: repeat(4, minmax(0,1fr)); gap:1rem; }
.pro-stat-card { padding:1rem; }
.pro-stat-card .label { display:block; color:var(--muted); font-size:.78rem; text-transform:uppercase; letter-spacing:.12em; font-weight:800; margin-bottom:.65rem; }
.pro-stat-card strong { display:block; font-size:2rem; margin-bottom:.25rem; }
.pro-grid-2 { display:grid; grid-template-columns: repeat(2, minmax(0,1fr)); gap:1rem; }
.pro-card { padding:1rem; min-width:0; }
.pro-card-title { margin:0 0 .9rem; color:var(--muted); font-size:.78rem; text-transform:uppercase; letter-spacing:.12em; font-weight:800; }
.pro-list { display:grid; gap:.75rem; }
.pro-list-item { padding:.9rem 1rem; border-radius:16px; border:1px solid var(--line); background:rgba(255,255,255,.03); }
.pro-list-item strong { display:block; line-height:1.35; }
.pro-list-item small, .pro-muted { display:block; color:var(--muted); line-height:1.5; }
.pro-table-wrap { overflow-x:auto; }
.pro-table { width:100%; border-collapse: collapse; min-width:780px; }
.pro-table th, .pro-table td { padding:14px 12px; border-bottom:1px solid var(--line); text-align:left; vertical-align:top; }
.pro-table th { color:var(--muted); font-size:.82rem; text-transform:uppercase; letter-spacing:.08em; }
.pro-pill { display:inline-flex; align-items:center; min-height:32px; padding:.38rem .65rem; border-radius:999px; border:1px solid var(--line); background:rgba(255,255,255,.04); font-size:.78rem; font-weight:700; }
.pro-severity-trusted { color:#7ee7c8; background:rgba(0,198,162,.12); border-color:rgba(0,198,162,.25); }
.pro-severity-low { color:#9ecbff; background:rgba(26,115,232,.12); border-color:rgba(26,115,232,.25); }
.pro-severity-moderate { color:#ffd36e; background:rgba(255,209,102,.14); border-color:rgba(255,209,102,.28); }
.pro-severity-high { color:#ff9a9a; background:rgba(255,127,127,.14); border-color:rgba(255,127,127,.25); }
.pro-severity-critical { color:#ff6b6b; background:rgba(255,80,80,.16); border-color:rgba(255,80,80,.3); }
.pro-alert-flag { color:#ff9a9a; }
@media (max-width: 1200px) { .pro-stats-grid { grid-template-columns: repeat(2, minmax(0,1fr)); } }
@media (max-width: 980px) {
  .pro-subheader { top:78px; }
  .pro-subheader-inner, .pro-layout, .pro-stats-grid, .pro-grid-2 { grid-template-columns:1fr; }
  .pro-sidebar { position:static; }
}
.pro-detail-layout {
    display: grid;
    grid-template-columns: 300px minmax(0, 1fr);
    gap: 1.25rem;
    align-items: start;
}

.pro-detail-sidebar,
.pro-detail-main {
    display: grid;
    gap: 1rem;
}

.pro-detail-sidebar {
    position: sticky;
    top: calc(78px + 68px + 1rem);
}

.pro-stat-stack {
    display: grid;
    gap: .75rem;
}

.pro-stat-line {
    display: flex;
    justify-content: space-between;
    gap: 1rem;
    padding: .8rem 0;
    border-top: 1px solid var(--line);
}

.pro-stat-line:first-child {
    border-top: 0;
    padding-top: 0;
}

.pro-stat-line strong {
    color: var(--text);
}

.pro-hero-card__top {
    display: flex;
    justify-content: space-between;
    gap: 1rem;
    align-items: start;
    flex-wrap: wrap;
}

.pro-score {
    font-size: 64px;
    font-weight: 900;
    line-height: 1;
    margin: .35rem 0 .5rem;
    letter-spacing: -1px;
}

.pro-score-trusted { color: #7ee7c8; }
.pro-score-low { color: #9ecbff; }
.pro-score-moderate { color: #ffd36e; }
.pro-score-high { color: #ff9a9a; }
.pro-score-critical { color: #ff6b6b; }

.pro-severity-pill {
    display: inline-flex;
    align-items: center;
    padding: 7px 12px;
    border-radius: 999px;
    border: 1px solid var(--line);
    font-size: 12px;
    font-weight: 700;
}

.pro-severity-pill-trusted { background: rgba(0,198,162,.12); color: #7ee7c8; }
.pro-severity-pill-low { background: rgba(26,115,232,.12); color: #9ecbff; }
.pro-severity-pill-moderate { background: rgba(255,209,102,.14); color: #ffd36e; }
.pro-severity-pill-high { background: rgba(255,127,127,.14); color: #ff9a9a; }
.pro-severity-pill-critical { background: rgba(255,80,80,.16); color: #ff6b6b; }

.pro-mini-metrics {
    display: grid;
    grid-template-columns: repeat(2, minmax(120px, 1fr));
    gap: .75rem;
}

.pro-mini-metric {
    padding: 1rem;
    border-radius: 16px;
    border: 1px solid var(--line);
    background: rgba(255,255,255,.03);
}

.pro-mini-metric strong {
    display: block;
    font-size: 1.35rem;
    margin-bottom: .25rem;
}

.pro-mini-metric span {
    color: var(--muted);
    font-size: .9rem;
}

.pro-alert-callout,
.pro-summary-box {
    margin-top: 1rem;
    padding: 1rem;
    border-radius: 16px;
    border: 1px solid var(--line);
    background: rgba(255,255,255,.03);
    line-height: 1.65;
}

.pro-alert-callout {
    border-color: rgba(255,127,127,.24);
    background: rgba(255,127,127,.08);
}

.pro-action-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: .85rem;
}

.pro-action-grid a {
    display: block;
    padding: .95rem 1rem;
    border-radius: 14px;
    border: 1px solid var(--line);
    background: rgba(255,255,255,.03);
    color: var(--text);
    text-decoration: none;
    font-weight: 700;
}

.pro-signal-group-list {
    display: grid;
    gap: 1rem;
}

.pro-signal-group h3 {
    margin: 0 0 .8rem;
    font-size: .9rem;
    text-transform: uppercase;
    letter-spacing: .08em;
    color: var(--muted);
}

.pro-signal-card {
    padding: 1rem;
    border-radius: 16px;
    border: 1px solid var(--line);
    background: rgba(255,255,255,.03);
    margin-bottom: .75rem;
}

.pro-signal-card:last-child {
    margin-bottom: 0;
}

.pro-signal-card__title {
    font-weight: 700;
    margin-bottom: .4rem;
}

.pro-signal-card__meta {
    color: var(--muted);
    font-size: .88rem;
    margin-bottom: .5rem;
    line-height: 1.5;
}

.pro-json-box {
    margin: 0;
    padding: 1rem;
    border-radius: 16px;
    border: 1px solid var(--line);
    background: rgba(255,255,255,.03);
    color: var(--muted);
    white-space: pre-wrap;
    word-break: break-word;
    overflow: auto;
    max-height: 420px;
    line-height: 1.55;
    font-size: 13px;
}

@media (max-width: 980px) {
    .pro-detail-layout,
    .pro-action-grid,
    .pro-mini-metrics {
        grid-template-columns: 1fr;
    }

    .pro-detail-sidebar {
        position: static;
    }
}
.pro-alert-list {
    display: grid;
    gap: 1rem;
}

.pro-alert-card {
    padding: 1rem;
}

.pro-alert-card__top {
    display: flex;
    justify-content: space-between;
    gap: 1rem;
    align-items: start;
    flex-wrap: wrap;
}

.pro-alert-card__meta {
    display: flex;
    flex-wrap: wrap;
    gap: 1rem;
    margin-top: 1rem;
    color: var(--muted);
    font-size: .92rem;
    line-height: 1.5;
}

.pro-alert-card__meta strong {
    color: var(--text);
}

.pro-asset-link {
    color: var(--text);
    text-decoration: none;
}

.pro-asset-link:hover {
    color: var(--primary);
}
.pro-table-actions {
    display: flex;
    flex-wrap: wrap;
    gap: .5rem;
}

.pro-table-action {
    min-height: 36px;
    padding: .55rem .8rem;
}

.pro-metric-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 1rem;
    margin-bottom: 1rem;
}

.pro-metric-card strong {
    display: block;
    font-size: 2rem;
    margin: .35rem 0 .45rem;
}

.pro-content-grid {
    display: grid;
    grid-template-columns: 1.2fr .8fr;
    gap: 1rem;
    align-items: start;
}

.pro-asset-list {
    display: grid;
    gap: .75rem;
}

.pro-asset-list-item {
    display: flex;
    justify-content: space-between;
    gap: 1rem;
    align-items: start;
    padding: 1rem;
    border-radius: 16px;
    border: 1px solid var(--line);
    background: rgba(255,255,255,.03);
    color: var(--text);
    text-decoration: none;
}

.pro-asset-list-item__meta {
    display: flex;
    flex-wrap: wrap;
    gap: .5rem;
    justify-content: flex-end;
}

@media (max-width: 1100px) {
    .pro-metric-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .pro-content-grid {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 720px) {
    .pro-metric-grid {
        grid-template-columns: 1fr;
    }

    .pro-asset-list-item {
        flex-direction: column;
    }

    .pro-asset-list-item__meta {
        justify-content: flex-start;
    }
}
/* Notes styling upgrade */
.pro-note-card {
    padding: 1rem;
    border-radius: 16px;
    border: 1px solid var(--line);
    background: rgba(255,255,255,.03);
    transition: all .2s ease;
}
.pro-note-list {
    display: grid;
    gap: 1rem;
}

.pro-note-card:hover {
    border-color: rgba(255,255,255,.2);
    background: rgba(255,255,255,.05);
}

.pro-note-recommendation {
    border-left: 3px solid #1a73e8;
}

.pro-note-status {
    border-left: 3px solid #00c6a2;
}

.pro-note-analyst {
    border-left: 3px solid #b56eff;
}

.login-step {
    display: none;
    animation: fadeIn .25s ease;
}

.login-step.active {
    display: block;
}

@keyframes fadeIn {
    from { opacity: 0; transform: translateY(6px); }
    to { opacity: 1; transform: translateY(0); }
}

.pro-form-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1rem;
}

.pro-form-grid label {
    display: grid;
    gap: .45rem;
    font-weight: 600;
}

.pro-form-grid input,
.pro-form-grid select,
.pro-form-grid textarea {
    width: 100%;
    border-radius: 14px;
    border: 1px solid var(--line);
    background: rgba(255,255,255,.04);
    color: var(--text);
    padding: .9rem 1rem;
    font: inherit;
}

.pro-form-grid textarea {
    resize: vertical;
    min-height: 140px;
}

@media (max-width: 720px) {
    .pro-form-grid {
        grid-template-columns: 1fr;
    }
}

.pro-subheader {
    border-bottom: 1px solid var(--line);
    background: rgba(255,255,255,.03);
    backdrop-filter: blur(8px);
}

.pro-subheader-inner {
    display: grid;
    grid-template-columns: auto 1fr auto;
    align-items: center;
    gap: 1.25rem;
    min-height: 62px;
}

.pro-subheader-context {
    display: inline-flex;
    align-items: center;
    gap: .45rem;
    white-space: nowrap;
    min-width: 0;
}

.pro-subheader-kicker {
    font-size: .78rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .12em;
    color: var(--muted);
}

.pro-subheader-separator {
    color: var(--muted);
    opacity: .7;
}

.pro-subheader-client {
    font-size: .92rem;
    font-weight: 600;
    color: var(--text);
    overflow: hidden;
    text-overflow: ellipsis;
}

.pro-subnav {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 1rem;
    flex-wrap: wrap;
}

.pro-subnav a {
    text-decoration: none;
    color: var(--muted);
    font-size: .92rem;
    font-weight: 600;
    padding: .45rem .1rem;
    border-bottom: 2px solid transparent;
    transition: color .18s ease, border-color .18s ease;
}

.pro-subnav a:hover {
    color: var(--text);
}

.pro-subnav a.is-active {
    color: var(--text);
    border-bottom-color: var(--primary);
}

.pro-subheader-actions {
    display: inline-flex;
    align-items: center;
    gap: .85rem;
    white-space: nowrap;
}

.pro-subheader-user {
    display: inline-flex;
    flex-direction: column;
    align-items: flex-end;
    line-height: 1.2;
}

.pro-subheader-user strong {
    font-size: .88rem;
    color: var(--text);
    font-weight: 700;
}

.pro-subheader-user span {
    font-size: .74rem;
    color: var(--muted);
}

.pro-subheader-logout {
    text-decoration: none;
    color: var(--text);
    font-size: .85rem;
    font-weight: 600;
    padding: .45rem .75rem;
    border: 1px solid var(--line);
    border-radius: 10px;
    transition: background .18s ease, border-color .18s ease;
}

.pro-subheader-logout:hover {
    background: rgba(255,255,255,.05);
}

@media (max-width: 1100px) {
    .pro-subheader-inner {
        grid-template-columns: 1fr;
        align-items: start;
        gap: .85rem;
        padding: .8rem 0;
    }

    .pro-subnav {
        justify-content: flex-start;
        row-gap: .5rem;
    }

    .pro-subheader-actions {
        justify-content: space-between;
    }

    .pro-subheader-user {
        align-items: flex-start;
    }
}
.pro-subheader {
    border-bottom: 1px solid var(--line);
    background: rgba(255,255,255,.03);
    backdrop-filter: blur(8px);
}

.pro-subheader-inner {
    display: grid;
    grid-template-columns: auto 1fr auto;
    align-items: center;
    gap: 1.25rem;
    min-height: 62px;
}

.pro-subheader-context {
    display: inline-flex;
    align-items: center;
    gap: .45rem;
    white-space: nowrap;
    min-width: 0;
}

.pro-subheader-kicker {
    font-size: .78rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .12em;
    color: var(--muted);
}

.pro-subheader-separator {
    color: var(--muted);
    opacity: .7;
}

.pro-subheader-client {
    font-size: .92rem;
    font-weight: 600;
    color: var(--text);
    overflow: hidden;
    text-overflow: ellipsis;
}

.pro-subnav {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 1rem;
    flex-wrap: wrap;
}

.pro-subnav a {
    text-decoration: none;
    color: var(--muted);
    font-size: .92rem;
    font-weight: 600;
    padding: .45rem .1rem;
    border-bottom: 2px solid transparent;
    transition: color .18s ease, border-color .18s ease;
}

.pro-subnav a:hover {
    color: var(--text);
}

.pro-subnav a.is-active {
    color: var(--text);
    border-bottom-color: var(--primary);
}

.pro-subheader-actions {
    display: inline-flex;
    align-items: center;
    justify-content: flex-end;
}

.pro-account-menu {
    position: relative;
}

.pro-account-trigger {
    border: 1px solid var(--line);
    background: rgba(255,255,255,.03);
    border-radius: 999px;
    width: 42px;
    height: 42px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    padding: 0;
}

.pro-account-trigger:hover {
    background: rgba(255,255,255,.06);
}

.pro-account-avatar {
    width: 30px;
    height: 30px;
    border-radius: 999px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: linear-gradient(135deg, var(--primary), #3f8cff);
    color: #fff;
    font-size: .88rem;
    font-weight: 800;
}

.pro-account-dropdown {
    position: absolute;
    top: calc(100% + 10px);
    right: 0;
    width: 240px;
    background: var(--panel);
    border: 1px solid var(--line);
    border-radius: 16px;
    box-shadow: var(--shadow);
    padding: .5rem;
    z-index: 50;
}

.pro-account-dropdown-head {
    padding: .7rem .8rem .85rem;
    border-bottom: 1px solid var(--line);
    margin-bottom: .35rem;
}

.pro-account-dropdown-head strong {
    display: block;
    color: var(--text);
    font-size: .92rem;
    line-height: 1.2;
}

.pro-account-dropdown-head span {
    display: block;
    color: var(--muted);
    font-size: .78rem;
    margin-top: .25rem;
    line-height: 1.4;
}

.pro-account-dropdown-links {
    display: grid;
}

.pro-account-dropdown-links a {
    text-decoration: none;
    color: var(--text);
    font-size: .9rem;
    padding: .75rem .8rem;
    border-radius: 12px;
    transition: background .18s ease;
}

.pro-account-dropdown-links a:hover {
    background: rgba(255,255,255,.05);
}

@media (max-width: 1100px) {
    .pro-subheader-inner {
        grid-template-columns: 1fr;
        align-items: start;
        gap: .85rem;
        padding: .8rem 0;
    }

    .pro-subnav {
        justify-content: flex-start;
        row-gap: .5rem;
    }

    .pro-subheader-actions {
        justify-content: flex-start;
    }
}

.pro-nav-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 18px;
    height: 18px;
    padding: 0 6px;
    margin-left: 6px;
    border-radius: 999px;
    background: #d93025;
    color: #fff;
    font-size: .72rem;
    font-weight: 800;
    line-height: 1;
    vertical-align: middle;
}

.pro-account-trigger {
    position: relative;
}

.pro-account-alert-dot {
    position: absolute;
    top: 2px;
    right: 2px;
    width: 10px;
    height: 10px;
    border-radius: 999px;
    background: #d93025;
    border: 2px solid var(--panel);
}

.pro-role-chip {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: .2rem .5rem;
    border-radius: 999px;
    border: 1px solid var(--line);
    font-size: .72rem;
    font-weight: 700;
    color: var(--muted);
    background: rgba(255,255,255,.03);
}
.pro-metric-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 1rem;
}

.pro-metric-card strong {
    display: block;
    font-size: 2rem;
    line-height: 1;
    margin: .35rem 0 .5rem;
}

.pro-metric-card p {
    margin: 0;
    color: var(--muted);
}

@media (max-width: 980px) {
    .pro-metric-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 640px) {
    .pro-metric-grid {
        grid-template-columns: 1fr;
    }
}

.admin-user-actions {
    display: grid;
    gap: .5rem;
    min-width: 220px;
}

.admin-user-actions input,
.admin-user-role,
.admin-user-status {
    width: 100%;
    border-radius: 10px;
    border: 1px solid var(--line);
    background: rgba(255,255,255,.04);
    color: var(--text);
    padding: .65rem .8rem;
    font: inherit;
}

.admin-user-status-message {
    font-size: .78rem;
}