/* Tokens da paleta oficial PEI Digital (reaproveitados de pei-layouts/gerados) */
:root {
    --pei-orange: #FE9629;
    --pei-green: #64C066;
    --pei-blue: #5496DD;
}

html, body {
    font-family: 'Helvetica Neue', Helvetica, Arial, sans-serif;
}

.pei-status-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 1rem;
    margin-top: 1rem;
}

.pei-card {
    border-radius: 12px;
    padding: 1.25rem;
    color: #fff;
}

.pei-card h3 { font-size: .9rem; opacity: .9; margin: 0 0 .25rem; }
.pei-card .value { font-size: 1.4rem; font-weight: 700; word-break: break-word; }
.pei-card--orange { background: var(--pei-orange); }
.pei-card--green { background: var(--pei-green); }
.pei-card--blue { background: var(--pei-blue); }

a, .btn-link {
    color: #006bb7;
}

.btn-primary {
    color: #fff;
    background-color: #1b6ec2;
    border-color: #1861ac;
}

.btn:focus, .btn:active:focus, .btn-link.nav-link:focus, .form-control:focus, .form-check-input:focus {
  box-shadow: 0 0 0 0.1rem white, 0 0 0 0.25rem #258cfb;
}

.content {
    padding-top: 1.1rem;
}

h1:focus {
    outline: none;
}

.valid.modified:not([type=checkbox]) {
    outline: 1px solid #26b050;
}

.invalid {
    outline: 1px solid #e50000;
}

.validation-message {
    color: #e50000;
}

.blazor-error-boundary {
    background: url(data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iNTYiIGhlaWdodD0iNDkiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgeG1sbnM6eGxpbms9Imh0dHA6Ly93d3cudzMub3JnLzE5OTkveGxpbmsiIG92ZXJmbG93PSJoaWRkZW4iPjxkZWZzPjxjbGlwUGF0aCBpZD0iY2xpcDAiPjxyZWN0IHg9IjIzNSIgeT0iNTEiIHdpZHRoPSI1NiIgaGVpZ2h0PSI0OSIvPjwvY2xpcFBhdGg+PC9kZWZzPjxnIGNsaXAtcGF0aD0idXJsKCNjbGlwMCkiIHRyYW5zZm9ybT0idHJhbnNsYXRlKC0yMzUgLTUxKSI+PHBhdGggZD0iTTI2My41MDYgNTFDMjY0LjcxNyA1MSAyNjUuODEzIDUxLjQ4MzcgMjY2LjYwNiA1Mi4yNjU4TDI2Ny4wNTIgNTIuNzk4NyAyNjcuNTM5IDUzLjYyODMgMjkwLjE4NSA5Mi4xODMxIDI5MC41NDUgOTIuNzk1IDI5MC42NTYgOTIuOTk2QzI5MC44NzcgOTMuNTEzIDI5MSA5NC4wODE1IDI5MSA5NC42NzgyIDI5MSA5Ny4wNjUxIDI4OS4wMzggOTkgMjg2LjYxNyA5OUwyNDAuMzgzIDk5QzIzNy45NjMgOTkgMjM2IDk3LjA2NTEgMjM2IDk0LjY3ODIgMjM2IDk0LjM3OTkgMjM2LjAzMSA5NC4wODg2IDIzNi4wODkgOTMuODA3MkwyMzYuMzM4IDkzLjAxNjIgMjM2Ljg1OCA5Mi4xMzE0IDI1OS40NzMgNTMuNjI5NCAyNTkuOTYxIDUyLjc5ODUgMjYwLjQwNyA1Mi4yNjU4QzI2MS4yIDUxLjQ4MzcgMjYyLjI5NiA1MSAyNjMuNTA2IDUxWk0yNjMuNTg2IDY2LjAxODNDMjYwLjczNyA2Ni4wMTgzIDI1OS4zMTMgNjcuMTI0NSAyNTkuMzEzIDY5LjMzNyAyNTkuMzEzIDY5LjYxMDIgMjU5LjMzMiA2OS44NjA4IDI1OS4zNzEgNzAuMDg4N0wyNjEuNzk1IDg0LjAxNjEgMjY1LjM4IDg0LjAxNjEgMjY3LjgyMSA2OS43NDc1QzI2Ny44NiA2OS43MzA5IDI2Ny44NzkgNjkuNTg3NyAyNjcuODc5IDY5LjMxNzkgMjY3Ljg3OSA2Ny4xMTgyIDI2Ni40NDggNjYuMDE4MyAyNjMuNTg2IDY2LjAxODNaTTI2My41NzYgODYuMDU0N0MyNjEuMDQ5IDg2LjA1NDcgMjU5Ljc4NiA4Ny4zMDA1IDI1OS43ODYgODkuNzkyMSAyNTkuNzg2IDkyLjI4MzcgMjYxLjA0OSA5My41Mjk1IDI2My41NzYgOTMuNTI5NSAyNjYuMTE2IDkzLjUyOTUgMjY3LjM4NyA5Mi4yODM3IDI2Ny4zODcgODkuNzkyMSAyNjcuMzg3IDg3LjMwMDUgMjY2LjExNiA4Ni4wNTQ3IDI2My41NzYgODYuMDU0N1oiIGZpbGw9IiNGRkU1MDAiIGZpbGwtcnVsZT0iZXZlbm9kZCIvPjwvZz48L3N2Zz4=) no-repeat 1rem/1.8rem, #b32121;
    padding: 1rem 1rem 1rem 3.7rem;
    color: white;
}

    .blazor-error-boundary::after {
        content: "An error has occurred."
    }

.darker-border-checkbox.form-check-input {
    border-color: #929292;
}

.form-floating > .form-control-plaintext::placeholder, .form-floating > .form-control::placeholder {
    color: var(--bs-secondary-color);
    text-align: end;
}

.form-floating > .form-control-plaintext:focus::placeholder, .form-floating > .form-control:focus::placeholder {
    text-align: start;
}

/* ───────────────────────────────────────────────────────────────────────────
   White-label do tema Syncfusion Fluent 2: reaponta as variáveis da cor primária
   para as CSS vars do tenant (rgb(var(--emerald-*-rgb)), definidas por rede pelo
   TenantThemeStyles). Carregado após fluent2.css → vence o :root padrão.
   As demais --color-sf-primary-* são var(...) e seguem estas automaticamente.
   ─────────────────────────────────────────────────────────────────────────── */
:root {
    --color-sf-primary: rgb(var(--emerald-700-rgb));
    --color-sf-primary-bg-color-hover: rgb(var(--emerald-800-rgb));
    --color-sf-primary-bg-color-pressed: rgb(var(--emerald-900-rgb));
    --color-sf-primary-bg-color-selected: rgb(var(--emerald-800-rgb));
    --color-sf-primary-dark: rgb(var(--emerald-800-rgb));
    --color-sf-primary-darker: rgb(var(--emerald-900-rgb));
    --color-sf-primary-light: rgb(var(--emerald-300-rgb));
    --color-sf-primary-lighter: rgb(var(--emerald-50-rgb));
    --color-sf-primary-cell-selection: rgb(var(--emerald-50-rgb));
    --color-sf-primary-label-color: rgb(var(--emerald-700-rgb));
    --color-sf-primary-text-color: #fff;
}

/* ── Padrão dos grids Syncfusion (Redes e demais) ──────────────────────────
   Botão de exportar (toolbar) alinhado à direita do grid. */
.e-grid .e-toolbar { width: 100% !important; }
.e-grid .e-toolbar .e-toolbar-items { display: flex !important; width: 100% !important; justify-content: flex-end !important; }

/* ── Coluna de Ações fixa à direita (sticky) ───────────────────────────────
   Última coluna do grid fica pinada à direita; as demais rolam por baixo dela
   (scrollbar horizontal no tbody). Aplica em header e células do corpo. */
.e-grid .e-gridheader .e-headercell:last-child,
.e-grid .e-content .e-rowcell:last-child {
    position: sticky;
    right: 0;
    z-index: 3;
    background-color: #fff;
    box-shadow: -8px 0 8px -8px rgba(15, 23, 41, .18);
}
.e-grid .e-gridheader .e-headercell:last-child {
    z-index: 4;
    background-color: var(--color-sf-content-bg-color-alt, #f5f5f5);
}
/* realça a borda esquerda da coluna fixa */
.e-grid .e-content .e-rowcell:last-child { border-left: 1px solid var(--color-sf-border-light-color, #eaeaea); }
/* hover da linha reflete na célula fixa de Ações */
.e-grid.e-gridhover .e-content tr.e-row:hover .e-rowcell:last-child {
    background-color: var(--color-sf-row-hover-bg-color, #f5f5f5);
}

/* ── Botões de ação do grid: só ícone, sem borda, com hover sutil ───────────── */
.pei-grid-action {
    border: 0;
    background: transparent;
    padding: 4px;
    border-radius: 8px;
    cursor: pointer;
    line-height: 0;
    color: #4C5563; /* ink-600 */
    display: inline-flex;
    align-items: center;
    justify-content: center;
    transition: background-color .12s ease, color .12s ease;
}
.pei-grid-action:hover { background: rgba(15, 23, 41, .07); color: #0F1729; }
.pei-grid-action:focus-visible { outline: 2px solid rgb(var(--emerald-500-rgb)); outline-offset: 1px; }
.pei-grid-action.is-danger { color: #dc2626; }
.pei-grid-action.is-danger:hover { background: rgba(220, 38, 38, .10); color: #b91c1c; }
.pei-grid-action.is-success { color: rgb(var(--emerald-600-rgb)); }
.pei-grid-action.is-success:hover { background: rgb(var(--emerald-500-rgb) / .12); }

/* linhas mais finas: reduz o padding vertical das células */
.e-grid .e-rowcell, .e-grid .e-gridheader .e-headercell { padding-top: 4px; padding-bottom: 4px; }

/* ── Formulários profissionais (edição de rede e demais) ───────────────────── */
.pei-form-card {
    background: #fff;
    border: 1px solid #E9EDF3;
    border-radius: 16px;
    padding: 22px 24px;
    box-shadow: 0 1px 2px rgba(15, 23, 41, .04);
}
.pei-form-title {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 15px;
    font-weight: 600;
    color: #343C49;
    margin-bottom: 18px;
    padding-bottom: 12px;
    border-bottom: 1px solid #F0F2F6;
}
.pei-label {
    display: block;
    font-size: 12.5px;
    font-weight: 500;
    color: #6B7585;
    margin-bottom: 5px;
}

/* ═══════════════ Wizard em modal full-screen (cadastros) ═══════════════════
   Sidebar escura com stepper de 2 linhas + conteúdo claro + barra de progresso.
   Acentos usam as cores do tenant via rgb(var(--emerald-*-rgb)). */
.pei-wzmodal-overlay {
    position: fixed; inset: 0; z-index: 60;
    background: rgba(8, 12, 20, .55);
    display: grid; place-items: center; padding: 22px;
}
.pei-wzmodal {
    width: 100%; height: 100%; max-width: 1420px; max-height: 940px;
    background: #fff; border-radius: 18px; overflow: hidden;
    display: flex; flex-direction: column; position: relative;
    box-shadow: 0 30px 90px rgba(8, 12, 20, .45);
}
.pei-wzmodal-progress { height: 3px; background: #141b2e; flex-shrink: 0; }
.pei-wzmodal-progress .bar {
    height: 100%; transition: width .35s ease;
    background: linear-gradient(90deg, rgb(var(--emerald-400-rgb)), rgb(var(--emerald-600-rgb)));
}
.pei-wzmodal-close {
    position: absolute; top: 14px; right: 16px; z-index: 5;
    width: 32px; height: 32px; border: 0; border-radius: 9px; cursor: pointer;
    background: rgba(255,255,255,.08); color: #c4cbda; display: grid; place-items: center;
}
.pei-wzmodal-close:hover { background: rgba(255,255,255,.16); color: #fff; }
.pei-wzmodal-body { flex: 1; min-height: 0; display: flex; }

/* sidebar */
.pei-wzside {
    width: 286px; flex-shrink: 0; background: #0F1729; color: #fff;
    display: flex; flex-direction: column; padding: 22px 16px;
}
.pei-wzside-brand { display: flex; gap: 12px; align-items: center; padding: 4px 8px 18px; }
.pei-wzside-brand .ico {
    width: 42px; height: 42px; border-radius: 12px; flex-shrink: 0;
    background: rgb(var(--emerald-500-rgb) / .18); color: rgb(var(--emerald-300-rgb));
    display: grid; place-items: center;
}
.pei-wzside-brand .t { font-weight: 700; font-size: 15px; line-height: 1.2; }
.pei-wzside-brand .s { font-size: 12px; color: #8b93a7; font-family: ui-monospace, monospace; margin-top: 2px; }
.pei-wzsteps { flex: 1; display: flex; flex-direction: column; gap: 3px; margin-top: 6px; }
.pei-wzstep {
    display: flex; gap: 12px; align-items: center; text-align: left;
    padding: 10px 12px; border-radius: 12px; background: transparent; border: 0;
    cursor: pointer; color: #aeb6c8; transition: background .15s, color .15s; width: 100%;
}
.pei-wzstep:hover { background: rgba(255, 255, 255, .05); }
.pei-wzstep.is-active { background: rgba(255, 255, 255, .08); color: #fff; }
.pei-wzstep .num {
    width: 27px; height: 27px; border-radius: 50%; flex-shrink: 0;
    display: grid; place-items: center; font-size: 12.5px; font-weight: 600;
    border: 1.5px solid #2c3650; color: #8b93a7; transition: all .15s;
}
.pei-wzstep.is-active .num, .pei-wzstep.is-done .num {
    background: rgb(var(--emerald-600-rgb)); border-color: rgb(var(--emerald-600-rgb)); color: #fff;
}
.pei-wzstep .lbl { display: flex; flex-direction: column; line-height: 1.25; min-width: 0; }
.pei-wzstep .lbl .t { font-size: 13.5px; font-weight: 600; }
.pei-wzstep .lbl .s { font-size: 11.5px; color: #7e879b; }
.pei-wzstep.is-active .lbl .s { color: #aab2c4; }
.pei-wzside-foot { font-size: 11px; color: #5b6479; padding: 10px 8px 2px; font-family: ui-monospace, monospace; }

/* conteúdo */
.pei-wzcontent { flex: 1; min-width: 0; display: flex; flex-direction: column; background: #F6F7FA; }
.pei-wzscroll { flex: 1; overflow-y: auto; padding: 30px 36px; }
.pei-wzhead h1 { font-size: 22px; font-weight: 700; color: #0F1729; line-height: 1.2; }
.pei-wzhead p { font-size: 14px; color: #6B7585; margin-top: 5px; margin-bottom: 24px; }
.pei-wznav {
    display: flex; align-items: center; justify-content: space-between;
    padding: 15px 36px; border-top: 1px solid #E9EDF3; background: #fff; flex-shrink: 0;
}
.pei-wznav .passo { font-size: 12.5px; color: #97A1B0; font-family: ui-monospace, monospace; }
.pei-wznav .acts { display: flex; gap: 10px; }

/* ── Passo Logo & Cores do wizard ──────────────────────────────────────────── */
.pei-logo-card {
    background: #fff; border: 1px solid #E9EDF3; border-radius: 14px;
    padding: 14px; display: flex; flex-direction: column;
}
.pei-logo-preview {
    height: 92px; border-radius: 10px; background: #F3F5F9; border: 1px solid #EAEEF4;
    display: grid; place-items: center; overflow: hidden; margin-bottom: 12px;
}
.pei-logo-preview.is-dark { background: #0F1729; border-color: #0F1729; }
.pei-logo-preview img { max-height: 62px; max-width: 86%; object-fit: contain; }
.pei-logo-preview img.is-favicon { max-height: 44px; max-width: 44px; }
.pei-logo-preview .empty {
    display: inline-flex; flex-direction: column; align-items: center; gap: 4px;
    font-size: 11px; color: #aab2c0;
}
.pei-logo-preview.is-dark .empty { color: #5b6479; }
.pei-logo-card .t { font-size: 13px; font-weight: 600; color: #343C49; }
.pei-logo-card .s { font-size: 11px; color: #97A1B0; margin: 2px 0 11px; line-height: 1.35; }
.pei-logo-card .pei-up { margin-top: auto; }

/* variante horizontal: miniatura à esquerda + texto/uploader à direita */
.pei-logo-card.is-row { flex-direction: row; align-items: center; gap: 14px; }
.pei-logo-card.is-row .pei-logo-preview {
    width: 104px; height: 68px; margin-bottom: 0; flex-shrink: 0;
}
.pei-logo-card.is-row .pei-logo-preview img { max-height: 46px; }
.pei-logo-card.is-row .pei-logo-preview img.is-favicon { max-height: 38px; max-width: 38px; }
.pei-logo-card.is-row .pei-logo-body { flex: 1; min-width: 0; display: flex; flex-direction: column; }
.pei-logo-card.is-row .pei-logo-body .s { margin-bottom: 8px; }
.pei-logo-card.is-row .pei-up { margin-top: 0; }
/* uploader compacto dentro do card */
.pei-up .e-file-select-wrap .e-file-drop { display: none; }
.pei-up .e-upload { border: 0; }
.pei-up .e-file-select-wrap { padding: 0; }

.pei-cor-grupo {
    font-size: 11px; font-weight: 600; text-transform: uppercase; letter-spacing: .06em;
    color: #97A1B0; margin-bottom: 7px;
}
.pei-cor-item {
    display: flex; align-items: center; gap: 11px;
    padding: 8px 11px; border: 1px solid #E9EDF3; border-radius: 11px; background: #fff;
}
.pei-cor-item .lbl { display: flex; flex-direction: column; line-height: 1.25; }
.pei-cor-item .lbl .t { font-size: 12.5px; font-weight: 600; color: #343C49; }
.pei-cor-item .lbl .s { font-size: 11px; color: #97A1B0; font-family: ui-monospace, monospace; }

/* Barra de progresso indeterminada (importação Educacenso) */
@keyframes pei-progress-indet {
  0%   { transform: translateX(-110%); }
  100% { transform: translateX(330%); }
}
.pei-progress-indet { animation: pei-progress-indet 1.1s ease-in-out infinite; }
