:root {
    --bg: #0b1020;
    --surface: #121a2e;
    --surface-2: #18233d;
    --line: #243150;
    --text: #e8edf7;
    --muted: #9aa6c0;
    --ok: #22c55e;
    --ok-bg: rgba(34, 197, 94, .12);
    --deg: #f59e0b;
    --deg-bg: rgba(245, 158, 11, .12);
    --fora: #ef4444;
    --fora-bg: rgba(239, 68, 68, .14);
    --check: #64748b;
    --radius: 16px;
    --font: 'Plus Jakarta Sans', system-ui, -apple-system, Segoe UI, Roboto, sans-serif;
}

* { box-sizing: border-box; }

html, body {
    margin: 0;
    padding: 0;
    background: var(--bg);
    color: var(--text);
    font-family: var(--font);
    -webkit-font-smoothing: antialiased;
}

a { color: inherit; text-decoration: none; }
code { font-family: ui-monospace, Menlo, Consolas, monospace; color: var(--muted); }

/* ---------- Shell ---------- */
.mc-shell { min-height: 100vh; display: flex; flex-direction: column; }

.mc-header {
    display: flex; align-items: center; gap: 16px;
    padding: 18px 28px; border-bottom: 1px solid var(--line);
    position: sticky; top: 0; z-index: 10;
    background: rgba(11, 16, 32, .85); backdrop-filter: blur(8px);
}
.mc-brand { display: flex; align-items: center; gap: 12px; }
.mc-logo-mark {
    width: 38px; height: 38px; border-radius: 11px;
    display: grid; place-items: center; font-weight: 800; font-size: 22px;
    color: #fff; background: linear-gradient(135deg, #ef4444, #b91c1c);
    box-shadow: 0 6px 18px rgba(239, 68, 68, .35);
}
.mc-brand-word { font-weight: 800; font-size: 18px; letter-spacing: .2px; }
.mc-brand-word em { font-style: normal; color: #ef4444; }
.mc-brand-sub { display: block; font-size: 12px; color: var(--muted); }
.mc-header-spacer { flex: 1; }
.mc-header-link { display: inline-flex; align-items: center; gap: 6px; color: var(--muted); font-size: 14px; }
.mc-header-link:hover { color: var(--text); }

.mc-main { flex: 1; width: 100%; max-width: 1180px; margin: 0 auto; padding: 28px 24px 48px; }

.mc-footer { border-top: 1px solid var(--line); padding: 18px 28px; }
.mc-footer-inner { max-width: 1180px; margin: 0 auto; display: flex; justify-content: space-between; gap: 12px; color: var(--muted); font-size: 13px; }
.mc-footer-tag em { font-style: normal; color: var(--text); }

/* ---------- Banner de destaque ---------- */
.mc-banner {
    position: relative; overflow: hidden;
    border-radius: var(--radius); border: 1px solid var(--line);
    padding: 30px 32px; margin-bottom: 26px;
    display: flex; align-items: center; gap: 20px; flex-wrap: wrap;
}
.mc-banner-body { flex: 1; min-width: 260px; }
.mc-banner-eyebrow { font-size: 12px; font-weight: 700; letter-spacing: 1.5px; text-transform: uppercase; color: var(--muted); }
.mc-banner-title { margin: 6px 0 4px; font-size: 38px; font-weight: 800; letter-spacing: .5px; }
.mc-banner-sub { margin: 0; color: var(--muted); font-size: 15px; }
.mc-banner-meta { display: flex; flex-direction: column; align-items: flex-end; gap: 6px; }
.mc-banner-clock { font-size: 13px; color: var(--muted); }
.mc-banner-sev { font-size: 12px; font-weight: 800; letter-spacing: 1px; padding: 4px 10px; border-radius: 999px; background: var(--fora-bg); color: var(--fora); }

.mc-banner-ok { background: linear-gradient(135deg, var(--ok-bg), transparent 70%); }
.mc-banner-ok .mc-banner-title { color: var(--ok); }
.mc-banner-fora { background: linear-gradient(135deg, var(--fora-bg), transparent 70%); border-color: rgba(239, 68, 68, .4); }
.mc-banner-fora .mc-banner-title { color: var(--fora); }
.mc-banner-check { background: linear-gradient(135deg, rgba(100, 116, 139, .14), transparent 70%); }
.mc-banner-check .mc-banner-title { color: var(--muted); }

.mc-banner-pulse {
    position: absolute; right: -40px; top: -40px; width: 200px; height: 200px;
    border-radius: 50%; pointer-events: none; opacity: .35; filter: blur(20px);
    background: currentColor;
}
.mc-banner-fora .mc-banner-pulse { color: var(--fora); animation: mc-pulse 1.6s ease-in-out infinite; }
.mc-banner-ok .mc-banner-pulse { color: var(--ok); }
.mc-banner-check .mc-banner-pulse { color: var(--check); }
@keyframes mc-pulse { 0%, 100% { opacity: .2; } 50% { opacity: .5; } }

/* ---------- Grid de servicos ---------- */
.mc-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(330px, 1fr)); gap: 18px; }

.mc-card {
    background: var(--surface); border: 1px solid var(--line);
    border-radius: var(--radius); padding: 20px; display: flex; flex-direction: column; gap: 10px;
    transition: transform .15s ease, border-color .15s ease;
}
.mc-card:hover { transform: translateY(-2px); }
.mc-card-ok { border-left: 4px solid var(--ok); }
.mc-card-deg { border-left: 4px solid var(--deg); }
.mc-card-fora { border-left: 4px solid var(--fora); background: linear-gradient(180deg, var(--fora-bg), var(--surface) 60%); }
.mc-card-check { border-left: 4px solid var(--check); }

.mc-card-top { display: flex; align-items: center; justify-content: space-between; }
.mc-pill { display: inline-flex; align-items: center; gap: 7px; font-size: 12px; font-weight: 800; letter-spacing: .8px; padding: 5px 11px; border-radius: 999px; }
.mc-dot { width: 8px; height: 8px; border-radius: 50%; background: currentColor; }
.mc-pill-ok { color: var(--ok); background: var(--ok-bg); }
.mc-pill-deg { color: var(--deg); background: var(--deg-bg); }
.mc-pill-fora { color: var(--fora); background: var(--fora-bg); }
.mc-pill-fora .mc-dot { animation: mc-blink 1s steps(2, start) infinite; }
.mc-pill-check { color: var(--check); background: rgba(100, 116, 139, .14); }
@keyframes mc-blink { 50% { opacity: .25; } }

.mc-lat { font-size: 12px; color: var(--muted); font-variant-numeric: tabular-nums; }

.mc-card-title { margin: 4px 0 0; font-size: 17px; font-weight: 700; }
.mc-card-url { font-size: 12px; color: var(--muted); word-break: break-all; }
.mc-card-url:hover { color: var(--text); text-decoration: underline; }
.mc-card-detail { margin: 4px 0; font-size: 14px; color: var(--text); }

.mc-card-impact {
    display: flex; align-items: flex-start; gap: 8px;
    background: var(--fora-bg); border: 1px solid rgba(239, 68, 68, .3);
    border-radius: 10px; padding: 10px 12px; font-size: 13.5px; color: #fecaca;
}
.mc-card-since { font-size: 12px; color: var(--fora); font-weight: 600; }

.mc-card-foot {
    margin-top: auto; padding-top: 10px; border-top: 1px solid var(--line);
    display: flex; flex-wrap: wrap; gap: 12px; font-size: 12px; color: var(--muted);
}

/* ---------- Erro ---------- */
.mc-erro { max-width: 560px; margin: 80px auto; text-align: center; }
.mc-erro h1 { font-size: 28px; }
.mc-erro-link { color: #3b82f6; }

/* ---------- Blazor error ui ---------- */
#blazor-error-ui {
    display: none; position: fixed; bottom: 0; left: 0; right: 0;
    background: #2a1216; color: #fecaca; padding: 12px 20px; font-size: 14px;
    border-top: 1px solid var(--fora); z-index: 1000;
}
#blazor-error-ui .reload { color: #fff; text-decoration: underline; margin-left: 8px; }
#blazor-error-ui .dismiss { cursor: pointer; float: right; }

@media (max-width: 640px) {
    .mc-banner-title { font-size: 28px; }
    .mc-banner-meta { align-items: flex-start; }
    .mc-main { padding: 18px 14px 40px; }
}
