:root {
    --bg: #050711;
    --bg-soft: #0b1020;
    --sidebar: #080d1c;
    --topbar: rgba(8, 11, 24, .86);
    --panel: rgba(15, 22, 40, .88);
    --panel-strong: #111a30;
    --panel-soft: rgba(122, 92, 255, .075);
    --text: #f7f8ff;
    --muted: #9ea8c4;
    --line: rgba(155, 178, 255, .16);
    --line-strong: rgba(139, 92, 246, .34);
    --primary: #7c5cff;
    --primary-2: #4f7cff;
    --primary-3: #c15cff;
    --success: #36d399;
    --warning: #fbbf24;
    --danger: #fb7185;
    --info: #60a5fa;
    --shadow: 0 22px 70px rgba(0, 0, 0, .42);
    --glow: 0 0 0 1px rgba(124, 92, 255, .18), 0 0 32px rgba(124, 92, 255, .16);
    --radius: 18px;
}

html[data-theme="light"] {
    --bg: #f3f6ff;
    --bg-soft: #e9efff;
    --sidebar: #ffffff;
    --topbar: rgba(255, 255, 255, .88);
    --panel: rgba(255, 255, 255, .9);
    --panel-strong: #ffffff;
    --panel-soft: rgba(80, 92, 255, .06);
    --text: #111827;
    --muted: #667085;
    --line: rgba(15, 23, 42, .11);
    --line-strong: rgba(80, 92, 255, .22);
    --shadow: 0 22px 70px rgba(31, 41, 55, .13);
}

* { box-sizing: border-box; }
html { min-height: 100%; }
body {
    margin: 0;
    min-height: 100vh;
    background:
        radial-gradient(circle at 16% -6%, rgba(124, 92, 255, .42), transparent 25rem),
        radial-gradient(circle at 72% 4%, rgba(79, 124, 255, .22), transparent 28rem),
        linear-gradient(135deg, rgba(9, 10, 28, .92), rgba(5, 7, 17, 1) 44%, rgba(13, 18, 38, 1)),
        var(--bg);
    color: var(--text);
    font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
    font-size: 14px;
}
html[data-theme="light"] body {
    background:
        radial-gradient(circle at 16% -6%, rgba(124, 92, 255, .15), transparent 24rem),
        radial-gradient(circle at 86% 0%, rgba(79, 124, 255, .14), transparent 24rem),
        var(--bg);
}

a { color: inherit; text-decoration: none; }
button, input, select, textarea { font: inherit; }
button { border: 0; }

.app-shell { display: grid; grid-template-columns: 250px minmax(0, 1fr); min-height: 100vh; }
.sidebar {
    position: sticky;
    top: 0;
    height: 100vh;
    padding: 14px 14px 18px;
    border-right: 1px solid var(--line);
    background: linear-gradient(180deg, rgba(13, 17, 37, .98), rgba(6, 10, 24, .96));
    box-shadow: 15px 0 50px rgba(0, 0, 0, .22);
    display: flex;
    flex-direction: column;
    z-index: 5;
}
html[data-theme="light"] .sidebar { background: rgba(255, 255, 255, .9); }

.brand, .brand-large { display: flex; align-items: center; gap: 11px; }
.brand {
    min-height: 54px;
    padding: 6px 6px 14px;
    border-bottom: 1px solid var(--line);
}
.brand-icon {
    width: 38px;
    height: 38px;
    object-fit: cover;
    border-radius: 12px;
    filter: drop-shadow(0 0 18px rgba(124, 92, 255, .38));
}
.brand strong, .brand-large strong { display: block; font-size: 15px; letter-spacing: -.02em; }
.brand small, .brand-large small { display: block; color: var(--muted); margin-top: 1px; font-size: 12px; }
.brand-mark {
    width: 42px; height: 42px; display: grid; place-items: center;
    border-radius: 15px;
    color: white; font-weight: 950; font-size: 24px;
    background: linear-gradient(135deg, var(--primary), var(--primary-2));
    box-shadow: 0 16px 38px rgba(124, 92, 255, .3);
}
.auth-logo-full { width: min(420px, 100%); height: auto; display: block; border-radius: 16px; }

.nav { display: grid; gap: 7px; margin-top: 18px; }
.nav a {
    display: flex;
    align-items: center;
    gap: 9px;
    min-height: 40px;
    padding: 10px 11px;
    border-radius: 10px;
    color: var(--muted);
    font-weight: 800;
    font-size: 13px;
    transition: .18s ease;
}
.nav a span { width: 17px; color: #d6d8ff; opacity: .86; }
.nav a:hover, .nav a.is-active {
    color: white;
    background: linear-gradient(90deg, rgba(124, 92, 255, .34), rgba(124, 92, 255, .12));
    box-shadow: inset 3px 0 0 var(--primary), 0 12px 28px rgba(91, 67, 222, .14);
}
html[data-theme="light"] .nav a:hover,
html[data-theme="light"] .nav a.is-active { color: #111827; background: rgba(124, 92, 255, .12); }
.nav a.is-disabled { opacity: .43; cursor: not-allowed; }
.sidebar-footer, .sidebar-footer-card { margin-top: auto; }
.sidebar-footer-card {
    border: 1px solid var(--line);
    border-radius: 14px;
    padding: 13px;
    background: rgba(255, 255, 255, .035);
    box-shadow: inset 0 1px 0 rgba(255,255,255,.03);
    display: grid;
    gap: 8px;
    color: var(--muted);
    font-size: 12px;
}
html[data-theme="light"] .sidebar-footer-card { background: rgba(15, 23, 42, .035); }
.mini-action { color: #c7d2fe; font-weight: 900; }
.sidebar-meta strong { display: block; color: var(--text); }
.sidebar-meta small { word-break: break-word; }
.sidebar-foot-row { display: flex; align-items: center; justify-content: space-between; }
.sidebar-foot-row a { color: var(--text); font-weight: 800; }

.main { min-width: 0; padding: 88px 28px 28px; position: relative; }
.topbar {
    position: fixed;
    top: 0;
    left: 250px;
    right: 0;
    z-index: 4;
    height: 58px;
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 20px;
    padding: 0 18px;
    border-bottom: 1px solid var(--line);
    background: var(--topbar);
    backdrop-filter: blur(22px);
    box-shadow: 0 10px 42px rgba(0,0,0,.24);
}
.topbar-left { display: flex; align-items: center; gap: 14px; min-width: 0; }
.menu-button {
    width: 37px; height: 37px; border-radius: 12px;
    border: 1px solid var(--line);
    background: rgba(255,255,255,.04);
    color: var(--text);
    font-size: 18px;
}
.topbar h1 { margin: 0; font-size: 16px; letter-spacing: -.02em; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.eyebrow { color: #b7c4ff; font-size: 10px; font-weight: 950; text-transform: uppercase; letter-spacing: .12em; }
.topbar-actions { display: flex; align-items: center; gap: 9px; flex-wrap: wrap; }
.user-pill, .theme-toggle, .btn, .system-pill {
    border: 1px solid var(--line);
    border-radius: 10px;
    padding: 9px 12px;
    color: var(--text);
    background: rgba(15, 23, 42, .58);
    box-shadow: none;
    white-space: nowrap;
}
html[data-theme="light"] .user-pill,
html[data-theme="light"] .theme-toggle,
html[data-theme="light"] .btn,
html[data-theme="light"] .system-pill { background: rgba(255, 255, 255, .7); }
.theme-toggle, .btn { cursor: pointer; }
.btn { display: inline-flex; align-items: center; justify-content: center; gap: 8px; font-weight: 900; }
.btn-primary { border: none; color: white; background: linear-gradient(135deg, var(--primary), var(--primary-3)); box-shadow: 0 12px 34px rgba(124, 92, 255, .32); }
.btn-soft { background: rgba(124, 92, 255, .13); color: var(--text); }
.btn-danger { background: rgba(251, 113, 133, .10); color: var(--danger); }
.system-pill { color: #e7e9ff; background: linear-gradient(135deg, rgba(124, 92, 255, .8), rgba(79, 124, 255, .7)); font-weight: 900; }

.metrics-grid { display: grid; grid-template-columns: repeat(5, minmax(0, 1fr)); gap: 16px; margin-bottom: 18px; }
.metric-card, .panel, .site-card, .auth-card {
    border: 1px solid var(--line);
    background: linear-gradient(180deg, var(--panel), rgba(9, 14, 28, .82));
    border-radius: var(--radius);
    box-shadow: var(--shadow);
    backdrop-filter: blur(20px);
}
html[data-theme="light"] .metric-card,
html[data-theme="light"] .panel,
html[data-theme="light"] .site-card,
html[data-theme="light"] .auth-card { background: var(--panel); }
.metric-card { padding: 18px; min-height: 124px; position: relative; overflow: hidden; }
.metric-card::before { content:""; position:absolute; inset:0; background: linear-gradient(135deg, rgba(124,92,255,.11), transparent 42%); pointer-events:none; }
.metric-card::after { content:""; position:absolute; right:-38px; bottom:-52px; width:130px; height:130px; border-radius:50%; background: rgba(79,124,255,.18); filter: blur(1px); }
.metric-card.primary { border-color: rgba(124, 92, 255, .35); box-shadow: var(--glow), var(--shadow); }
.metric-card.primary::after { background: rgba(124, 92, 255, .32); }
.metric-card.danger::after { background: rgba(251, 113, 133, .18); }
.metric-card.warn::after { background: rgba(251, 191, 36, .18); }
.metric-card span { color: var(--muted); font-weight: 900; position:relative; }
.metric-card strong { display: block; font-size: 38px; line-height: 1; letter-spacing: -.055em; margin-top: 15px; position:relative; }
.metric-card small { color: var(--muted); position:relative; }
.content-grid { display: grid; gap: 18px; margin-bottom: 18px; }
.content-grid.two { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.content-grid.uneven { grid-template-columns: 1.05fr .95fr; }
.panel { padding: 19px; }
.panel-header { display: flex; justify-content: space-between; align-items: center; gap: 18px; margin-bottom: 16px; }
.panel-header h2 { margin: 3px 0 0; font-size: 18px; letter-spacing: -.03em; }
.panel-header p { margin: 6px 0 0; }
.empty-state { padding: 26px; border: 1px dashed var(--line-strong); border-radius: 16px; color: var(--muted); text-align: center; background: rgba(124, 92, 255, .04); }
.alert { padding: 13px 15px; border-radius: 14px; margin: 0 0 18px; border:1px solid var(--line); }
.alert-success { background: rgba(54, 211, 153, .12); color: var(--success); }
.alert-error { background: rgba(251, 113, 133, .14); color: var(--danger); }
.issue-list { display: grid; gap: 11px; }
.issue-item { display: flex; gap: 12px; padding: 13px; border: 1px solid var(--line); border-radius: 14px; background: rgba(255,255,255,.03); }
.issue-item p { margin: 4px 0; color: var(--text); }
.issue-item small { display:block; color: var(--muted); margin-top: 3px; word-break: break-word; }
.severity { align-self: flex-start; min-width: 74px; text-align: center; padding: 5px 8px; border-radius: 999px; font-size: 10px; font-weight: 950; text-transform: uppercase; }
.severity-critical { background: rgba(251,113,133,.14); color: var(--danger); }
.severity-warning { background: rgba(251,191,36,.14); color: var(--warning); }
.severity-notice { background: rgba(96,165,250,.14); color: #93c5fd; }
.severity-success { background: rgba(54,211,153,.14); color: var(--success); }
.table { width: 100%; border-collapse: collapse; }
.table th, .table td { padding: 12px 11px; border-bottom: 1px solid var(--line); text-align: left; vertical-align: top; }
.table th { color: var(--muted); font-size: 11px; text-transform: uppercase; letter-spacing: .08em; background: rgba(124, 92, 255, .06); }
.table small { color: var(--muted); }
.score-pill, .cms-pill { display: inline-flex; align-items:center; justify-content:center; padding: 5px 9px; border-radius: 999px; background: rgba(124, 92, 255, .16); color: var(--text); font-weight: 900; }
.cms-pill { text-transform: capitalize; }
.form-grid { display: grid; gap: 14px; }
.form-grid.compact { grid-template-columns: 1fr auto; align-items: end; }
label { display: grid; gap: 7px; color: var(--muted); font-weight: 900; }
input, select, textarea {
    width: 100%; padding: 12px 13px; border-radius: 12px; border: 1px solid var(--line);
    color: var(--text); background: rgba(10, 15, 30, .88); outline: none;
}
html[data-theme="light"] input,
html[data-theme="light"] select,
html[data-theme="light"] textarea { background: #fff; }
input:focus, select:focus, textarea:focus { border-color: rgba(124, 92, 255, .68); box-shadow: 0 0 0 4px rgba(124, 92, 255, .14); }
.site-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 16px; }
.site-card { padding: 16px; transition: .18s ease; }
.site-card:hover { transform: translateY(-2px); border-color: var(--line-strong); box-shadow: var(--glow), var(--shadow); }
.site-card-head { display: flex; justify-content: space-between; gap: 12px; margin-bottom: 16px; }
.site-card-head strong { display: block; font-size: 17px; }
.site-card-head small { display: block; margin-top: 5px; color: var(--muted); word-break: break-word; }
.site-stats { display: grid; grid-template-columns: repeat(3, 1fr); gap: 10px; margin-bottom: 16px; }
.site-stats span { padding: 11px; border: 1px solid var(--line); border-radius: 12px; color: var(--muted); background: rgba(255,255,255,.025); }
.site-stats strong { display:block; color: var(--text); font-size: 20px; margin-top: 4px; }
.site-actions { display: flex; justify-content: space-between; gap: 10px; }
.site-actions form { flex: 1; }
.site-actions .btn { width: 100%; }
.roadmap { display: grid; grid-template-columns: repeat(5, 1fr); gap: 12px; }
.roadmap div { padding: 15px; border: 1px solid var(--line); border-radius: 15px; background: rgba(255,255,255,.03); }
.roadmap strong { display: grid; place-items: center; width: 32px; height: 32px; border-radius: 11px; background: linear-gradient(135deg, var(--primary), var(--primary-2)); color: white; margin-bottom: 11px; }
.muted { color: var(--muted); }
.check-list { display:grid; gap: 9px; padding-left: 18px; color: var(--muted); }
.auth-body { display: grid; place-items: center; padding: 24px; }
.auth-wrap { width: min(620px, 100%); }
.auth-card { padding: 31px; border-color: rgba(124, 92, 255, .24); box-shadow: var(--glow), var(--shadow); }
.auth-card h1 { font-size: 34px; margin: 24px 0 8px; letter-spacing: -.04em; }
.requirements { display: grid; grid-template-columns: repeat(2, 1fr); gap: 10px; margin: 22px 0; }
.requirement { padding: 12px; border: 1px solid var(--line); border-radius: 13px; color: var(--muted); background: rgba(255,255,255,.025); }
.requirement span { display: inline-grid; place-items: center; width: 22px; height: 22px; border-radius: 50%; margin-right: 8px; }
.requirement.ok span { background: rgba(54,211,153,.14); color: var(--success); }
.requirement.bad span { background: rgba(251,113,133,.14); color: var(--danger); }
.version-box { display:grid; gap: 8px; }
.version-box strong { font-size: 40px; letter-spacing:-.05em; }
.version-box small, .version-box span { color: var(--muted); }
.update-card { display:flex; align-items:center; justify-content:space-between; gap:20px; padding: 17px; border:1px solid var(--line); border-radius: 16px; background: rgba(124, 92, 255, .055); }
.update-card h3 { margin: 6px 0; font-size: 25px; }
.form-split { display:grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 14px; }
.db-mysql { display:grid; gap:14px; padding:14px; border:1px solid var(--line); border-radius:16px; background:rgba(255,255,255,.03); }
.db-mysql[hidden] { display:none; }
.site-stats.four { grid-template-columns: repeat(4,1fr); }
.scan-form { display:grid; grid-template-columns: 1fr auto; gap: 10px; align-items:end; margin-bottom: 12px; }
.scan-form .btn { height: 45px; }
.site-actions a.btn { width:100%; }
.inline-form { display:inline-flex; }
.metrics-grid.compact { grid-template-columns: repeat(4, minmax(0,1fr)); }
.metric-date { font-size: 22px !important; letter-spacing: -.03em !important; }
.scroll-list { max-height: 560px; overflow:auto; padding-right: 4px; }
.table-wrap { overflow:auto; border-radius: 14px; border: 1px solid var(--line); }
.table-wrap .table th:first-child { border-top-left-radius: 14px; }
.url-cell { display:block; max-width: 320px; word-break: break-all; }
.metrics-grid.six { grid-template-columns: repeat(6, minmax(0,1fr)); }

@media (max-width: 1300px) { .metrics-grid.six { grid-template-columns: repeat(3, minmax(0,1fr)); } }
@media (max-width: 1100px) {
    .app-shell { grid-template-columns: 1fr; }
    .sidebar { position: relative; height: auto; }
    .topbar { left: 0; }
    .main { padding-top: 86px; }
    .metrics-grid, .site-grid, .roadmap { grid-template-columns: repeat(2, minmax(0,1fr)); }
    .content-grid.two, .content-grid.uneven { grid-template-columns: 1fr; }
}
@media (max-width: 920px) {
    .site-stats.four, .metrics-grid.compact { grid-template-columns: repeat(2, minmax(0,1fr)); }
    .scan-form { grid-template-columns: 1fr; }
    .topbar { height: auto; min-height: 58px; padding: 10px 14px; align-items: flex-start; flex-direction: column; }
    .main { padding-top: 124px; }
}
@media (max-width: 680px) {
    .main { padding: 132px 16px 16px; }
    .metrics-grid, .site-grid, .roadmap, .requirements, .form-split, .site-stats.four, .metrics-grid.compact, .metrics-grid.six { grid-template-columns: 1fr; }
    .topbar, .panel-header, .update-card { align-items: stretch; }
    .form-grid.compact { grid-template-columns: 1fr; }
    .site-actions { flex-direction: column; }
}

/* v0.3.1 visual alignment hotfix: compact brand, cache-safe assets, Care Center purple/blue palette */
:root {
    --bg: #050814;
    --bg-soft: #0b1020;
    --sidebar: #070b16;
    --topbar: rgba(6, 9, 20, .92);
    --panel: rgba(14, 20, 36, .92);
    --panel-strong: #10182d;
    --panel-soft: rgba(109, 93, 255, .075);
    --text: #f8faff;
    --muted: #9aa6c3;
    --line: rgba(148, 163, 255, .14);
    --line-strong: rgba(109, 93, 255, .36);
    --primary: #6D5DFF;
    --primary-2: #3B82F6;
    --primary-3: #8B5CF6;
    --warning: #fbbf24;
    --shadow: 0 18px 54px rgba(0, 0, 0, .38);
    --glow: 0 0 0 1px rgba(109, 93, 255, .18), 0 0 28px rgba(59, 130, 246, .12);
}

body {
    background:
        radial-gradient(circle at 18% -8%, rgba(109, 93, 255, .28), transparent 24rem),
        radial-gradient(circle at 88% 0%, rgba(59, 130, 246, .18), transparent 26rem),
        linear-gradient(135deg, #080b19 0%, #050814 48%, #0a1022 100%),
        var(--bg);
}

.sidebar {
    background: linear-gradient(180deg, rgba(9, 13, 28, .98), rgba(5, 8, 18, .98));
}

.sidebar .brand {
    min-height: 58px;
    padding: 8px 7px 13px;
    gap: 10px;
    overflow: hidden;
}

.sidebar .brand img.brand-icon {
    width: 34px !important;
    height: 34px !important;
    min-width: 34px !important;
    max-width: 34px !important;
    max-height: 34px !important;
    object-fit: contain !important;
    display: block !important;
    border-radius: 10px;
    filter: drop-shadow(0 0 12px rgba(109, 93, 255, .28));
}

.sidebar .brand > span {
    min-width: 0;
    overflow: hidden;
}

.sidebar .brand strong {
    font-size: 13px;
    line-height: 1.15;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.sidebar .brand small {
    font-size: 11px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    max-width: 155px;
}

.auth-logo-full {
    width: min(360px, 100%) !important;
    max-height: 112px !important;
    object-fit: contain !important;
    display: block !important;
    border-radius: 0 !important;
}

.eyebrow {
    color: #aab6ff;
}

.nav a:hover,
.nav a.is-active {
    background: linear-gradient(90deg, rgba(109, 93, 255, .32), rgba(59, 130, 246, .10));
    box-shadow: inset 3px 0 0 var(--primary), 0 12px 28px rgba(59, 130, 246, .12);
}

.btn-primary {
    background: linear-gradient(135deg, #6D5DFF, #3B82F6) !important;
    box-shadow: 0 12px 34px rgba(59, 130, 246, .24) !important;
}

.btn-soft,
.theme-toggle,
.system-pill {
    background: rgba(15, 23, 42, .68);
}

.system-pill {
    color: #dce4ff;
    background: rgba(109, 93, 255, .16) !important;
    border-color: rgba(109, 93, 255, .28) !important;
}

.metric-card.primary,
.panel:hover {
    border-color: rgba(109, 93, 255, .28);
}

.panel,
.metric-card,
.site-card,
.auth-card {
    background: linear-gradient(180deg, rgba(14, 20, 36, .94), rgba(8, 12, 26, .9));
}

.alert-success {
    background: rgba(54, 211, 153, .11);
    border-color: rgba(54, 211, 153, .2);
}

/* v0.4.0 PageSpeed module */
.site-stats.five { grid-template-columns: repeat(5, 1fr); }
.site-actions.three-actions { grid-template-columns: repeat(3, 1fr); display: grid; }
.site-actions.three-actions form { min-width: 0; }
.site-actions.three-actions .btn { width: 100%; }
.mini-roadmap { grid-template-columns: repeat(4, minmax(0, 1fr)); }
.summary-row td { background: rgba(124, 92, 255, .035); color: var(--muted); }
.small-note { margin: 10px 0 0; font-size: 12px; }
@media (max-width: 1100px) { .site-stats.five { grid-template-columns: repeat(3, minmax(0,1fr)); } }
@media (max-width: 680px) { .site-stats.five, .mini-roadmap, .site-actions.three-actions { grid-template-columns: 1fr; } }

/* v0.5.0 Reports module */
.report-site-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.report-site-card .scan-form { grid-template-columns: 1fr; }
.row-actions { display:flex; align-items:center; gap: 8px; flex-wrap: wrap; }
.row-actions form { margin: 0; }
.report-roadmap { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.report-body {
    min-height: 100vh;
    background:
        radial-gradient(circle at 12% -10%, rgba(109, 93, 255, .24), transparent 26rem),
        radial-gradient(circle at 90% 0%, rgba(59, 130, 246, .13), transparent 26rem),
        #070b16;
    color: #f8faff;
}
.report-toolbar {
    position: sticky;
    top: 0;
    z-index: 10;
    display: flex;
    justify-content: space-between;
    gap: 12px;
    width: min(1120px, calc(100% - 40px));
    margin: 0 auto;
    padding: 14px 0;
}
.report-page {
    width: min(1120px, calc(100% - 40px));
    margin: 0 auto 44px;
    border: 1px solid rgba(148, 163, 255, .16);
    border-radius: 28px;
    background: linear-gradient(180deg, rgba(14,20,36,.96), rgba(8,12,26,.96));
    box-shadow: 0 28px 90px rgba(0,0,0,.45);
    overflow: hidden;
}
.report-hero {
    display: grid;
    grid-template-columns: 1fr 210px;
    gap: 26px;
    align-items: center;
    padding: 38px;
    border-bottom: 1px solid rgba(148, 163, 255, .16);
    background: linear-gradient(135deg, rgba(109,93,255,.22), rgba(59,130,246,.08) 48%, rgba(15,23,42,.28));
}
.report-logo { width: min(320px, 100%); max-height: 76px; object-fit: contain; display:block; margin-bottom: 18px; }
.report-hero h1 { margin: 8px 0 8px; font-size: 38px; line-height: 1.05; letter-spacing: -.04em; }
.report-hero p { margin: 0; color: #aab6d3; word-break: break-word; }
.report-score-card {
    border: 1px solid rgba(109, 93, 255, .3);
    border-radius: 24px;
    padding: 24px;
    text-align: center;
    background: rgba(7, 11, 22, .54);
    box-shadow: 0 0 34px rgba(109, 93, 255, .16);
}
.report-score-card span, .report-kpis span { color: #aab6d3; font-weight: 900; text-transform: uppercase; letter-spacing: .08em; font-size: 11px; }
.report-score-card strong { display:block; font-size: 64px; letter-spacing: -.06em; line-height: 1; margin: 12px 0; }
.report-score-card small { color: #c8d1f0; }
.report-section { padding: 30px 38px; border-bottom: 1px solid rgba(148, 163, 255, .12); }
.report-section h2 { margin: 0 0 14px; font-size: 24px; letter-spacing: -.03em; }
.report-section p { color: #c6cee3; line-height: 1.65; }
.report-kpis { display:grid; grid-template-columns: repeat(5, minmax(0, 1fr)); gap: 14px; }
.report-kpis article {
    border: 1px solid rgba(148, 163, 255, .14);
    border-radius: 18px;
    padding: 18px;
    background: rgba(255,255,255,.035);
}
.report-kpis strong { display:block; font-size: 36px; line-height: 1; letter-spacing: -.05em; margin-top: 10px; }
.report-kpis small { color: #aab6d3; }
.compact-report-kpis { grid-template-columns: repeat(5, minmax(0, 1fr)); }
.report-summary-box {
    display:grid;
    gap: 6px;
    padding: 18px;
    border-radius: 18px;
    border: 1px solid rgba(54, 211, 153, .22);
    background: rgba(54, 211, 153, .08);
}
.report-summary-box span { color: #aab6d3; }
.report-recommendations { display:grid; gap: 12px; }
.report-recommendations article {
    display:grid;
    grid-template-columns: 84px 1fr;
    gap: 16px;
    padding: 16px;
    border: 1px solid rgba(148, 163, 255, .14);
    border-radius: 18px;
    background: rgba(255,255,255,.03);
}
.report-recommendations h3 { margin: 0 0 6px; }
.report-recommendations p { margin: 0; }
.priority {
    display:inline-grid;
    place-items:center;
    height: 30px;
    border-radius: 999px;
    text-transform: uppercase;
    font-size: 10px;
    font-weight: 950;
}
.priority-high { background: rgba(251,113,133,.14); color: #fb7185; }
.priority-medium { background: rgba(251,191,36,.14); color: #fbbf24; }
.priority-low { background: rgba(96,165,250,.14); color: #93c5fd; }
.report-table { width:100%; border-collapse: collapse; font-size: 13px; }
.report-table th, .report-table td { padding: 11px 10px; border-bottom: 1px solid rgba(148, 163, 255, .13); text-align:left; vertical-align: top; }
.report-table th { color: #aab6d3; text-transform: uppercase; letter-spacing: .08em; font-size: 10px; }
.report-table small { color: #aab6d3; word-break: break-all; }
.report-table.compact { font-size: 12px; }
.report-history-grid { display:grid; grid-template-columns: repeat(2, minmax(0,1fr)); gap: 20px; }
.report-history-grid article { border: 1px solid rgba(148, 163, 255, .13); border-radius: 18px; padding: 18px; background: rgba(255,255,255,.025); overflow:auto; }
.report-history-grid h3 { margin: 0 0 12px; }
.report-footer { display:flex; justify-content:space-between; gap: 18px; padding: 24px 38px; color: #aab6d3; }
.report-footer strong { color: #f8faff; }
.page-break-avoid { break-inside: avoid; }
@media (max-width: 960px) {
    .report-hero, .report-history-grid { grid-template-columns: 1fr; }
    .report-kpis, .compact-report-kpis { grid-template-columns: repeat(2, minmax(0, 1fr)); }
    .report-site-grid { grid-template-columns: 1fr; }
}
@media print {
    * { box-shadow: none !important; text-shadow: none !important; }
    html, body, .report-body { background: #fff !important; color: #111827 !important; }
    .no-print { display:none !important; }
    .report-page { width: 100%; margin:0; border:0; border-radius:0; background:#fff !important; color:#111827 !important; }
    .report-hero, .report-section, .report-footer { background:#fff !important; color:#111827 !important; border-color:#e5e7eb !important; }
    .report-hero { padding: 24px 0; }
    .report-section { padding: 22px 0; }
    .report-footer { padding: 18px 0; }
    .report-score-card, .report-kpis article, .report-recommendations article, .report-history-grid article, .report-summary-box { background:#fff !important; border-color:#e5e7eb !important; }
    .report-section p, .report-hero p, .report-table small, .report-summary-box span, .report-footer, .report-kpis small, .report-score-card small { color:#4b5563 !important; }
    .report-logo { filter: none !important; }
    .report-table th, .report-table td { border-color:#e5e7eb !important; }
    .priority-high, .priority-medium, .priority-low { color:#111827 !important; background:#f3f4f6 !important; }
}

/* v0.6.0 Content AI module */
.content-suggestion-list { display: grid; gap: 16px; }
.content-suggestion-card {
    border: 1px solid var(--line);
    border-radius: 18px;
    padding: 17px;
    background: rgba(255,255,255,.028);
    box-shadow: inset 0 1px 0 rgba(255,255,255,.025);
}
.content-suggestion-head {
    display: flex;
    justify-content: space-between;
    gap: 18px;
    align-items: flex-start;
    margin-bottom: 16px;
}
.content-suggestion-head h3 { margin: 4px 0 5px; font-size: 20px; letter-spacing: -.03em; }
.content-suggestion-head small { display: block; color: var(--muted); word-break: break-all; }
.score-compare {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 8px;
    border: 1px solid var(--line);
    border-radius: 999px;
    background: rgba(109, 93, 255, .075);
    white-space: nowrap;
}
.score-compare span {
    display: inline-grid;
    place-items: center;
    min-width: 34px;
    height: 34px;
    border-radius: 50%;
    background: rgba(109, 93, 255, .16);
    font-weight: 950;
}
.score-compare strong { color: var(--muted); }
.content-ai-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 12px;
}
.content-ai-grid > div {
    border: 1px solid var(--line);
    border-radius: 14px;
    padding: 13px;
    background: rgba(255,255,255,.025);
}
.content-ai-grid p { margin: 5px 0 0; line-height: 1.5; }
.field-label {
    display: block;
    color: var(--muted);
    font-size: 10px;
    font-weight: 950;
    text-transform: uppercase;
    letter-spacing: .09em;
}
.faq-preview {
    margin-top: 13px;
    border: 1px solid var(--line);
    border-radius: 14px;
    padding: 12px 13px;
    background: rgba(109, 93, 255, .045);
}
.faq-preview summary { cursor: pointer; font-weight: 900; color: var(--text); }
.faq-grid { display: grid; gap: 10px; margin-top: 12px; }
.faq-grid article { border-top: 1px solid var(--line); padding-top: 10px; }
.faq-grid p { margin: 6px 0 0; color: var(--muted); line-height: 1.55; }
.content-roadmap { grid-template-columns: repeat(2, minmax(0,1fr)); }
.content-site-grid .site-card { min-height: 280px; }
@media (max-width: 920px) {
    .content-suggestion-head, .content-ai-grid { grid-template-columns: 1fr; display: grid; }
    .content-roadmap { grid-template-columns: 1fr; }
}

/* v0.8.0 CMS Connector module */
.connector-site-grid .site-card { min-height: 300px; }
.cms-action-card { position: relative; }
.code-block {
    margin: 12px 0 0;
    padding: 12px;
    border-radius: 12px;
    border: 1px solid var(--line);
    background: rgba(2, 6, 23, .38);
    color: var(--text);
    font-size: 12px;
    line-height: 1.55;
    white-space: pre-wrap;
    word-break: break-word;
    overflow: auto;
}
code {
    padding: 2px 6px;
    border-radius: 8px;
    background: rgba(109, 93, 255, .11);
    border: 1px solid rgba(109, 93, 255, .18);
    color: var(--text);
    font-size: .9em;
}

/* v0.8.3 Content AI refinement */
.editable-suggestion-form { display: grid; gap: 13px; }
.editable-content-ai-grid input,
.editable-content-ai-grid textarea,
.faq-edit-grid input,
.faq-edit-grid textarea,
.notes-editor textarea { font-size: 13px; }
.editable-content-ai-grid small { display: block; margin-top: 7px; }
.faq-edit-grid { display: grid; gap: 12px; margin-top: 12px; }
.faq-edit-grid article {
    display: grid;
    grid-template-columns: minmax(0, .8fr) minmax(0, 1.2fr);
    gap: 12px;
    padding: 12px;
    border: 1px solid var(--line);
    border-radius: 14px;
    background: rgba(255,255,255,.025);
}
.notes-editor { margin-top: 0; }
.suggestion-status-actions { margin-top: 12px; padding-top: 12px; border-top: 1px solid var(--line); }
.utility-note {
    margin: 0 0 13px;
    padding: 11px 13px;
    border: 1px solid rgba(96,165,250,.24);
    border-radius: 14px;
    background: rgba(96,165,250,.08);
    color: var(--muted);
    line-height: 1.5;
}
.utility-note strong { color: var(--text); }
.content-suggestion-card-utility { border-color: rgba(96,165,250,.22); }
.content-suggestion-card-utility .score-compare { background: rgba(96,165,250,.075); }
@media (max-width: 920px) {
    .faq-edit-grid article { grid-template-columns: 1fr; }
}
