/* =====================================================
   Admin v3 — Cockpit (/)
   Layout fiel ao design_handoff_responsive/page-cockpit.jsx
   ===================================================== */

.cockpit {
    max-width: var(--content-max);
    margin: 0 auto;
    display: flex;
    flex-direction: column;
    gap: var(--s-5);
}

/* ---------- Header com saudação ---------- */
.cockpit-greeting__eyebrow {
    font-size: var(--text-xs);
    color: var(--text-mute);
    text-transform: capitalize;
    margin: 0 0 var(--s-1);
}

.cockpit-greeting__title {
    font-family: var(--font-display);
    font-size: var(--text-2xl);
    font-weight: var(--fw-semibold);
    color: var(--text);
    letter-spacing: -0.01em;
    margin: 0;
    line-height: var(--lh-tight);
}

@media (min-width: 1024px) {
    .cockpit-greeting__title {
        font-size: var(--text-3xl);
    }
}

.cockpit-greeting__title-mute {
    color: var(--text-mute);
    font-weight: var(--fw-regular);
}

/* ---------- Filtro de período (chips) ---------- */
.cockpit-period {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: var(--s-2);
    padding: var(--s-3) 0;
    border-bottom: 1px solid var(--line);
    margin-bottom: var(--s-2);
}

.cockpit-period__chip {
    height: 32px;
    padding: 0 var(--s-3);
    border-radius: var(--r-pill);
    border: 1px solid var(--line);
    background: var(--bg-raised);
    color: var(--text-mute);
    font-size: var(--text-sm);
    font-weight: var(--fw-medium);
    cursor: pointer;
    transition: background var(--t-fast) var(--ease-out),
                border-color var(--t-fast) var(--ease-out),
                color var(--t-fast) var(--ease-out);
    white-space: nowrap;
}

.cockpit-period__chip:hover:not(:disabled) {
    background: var(--bg-hover);
    color: var(--text);
}

.cockpit-period__chip.is-active {
    background: var(--accent-soft);
    border-color: var(--accent);
    color: var(--accent);
}

.cockpit-period__chip:disabled {
    opacity: 0.55;
    cursor: not-allowed;
}

.cockpit-period__custom {
    display: flex;
    flex-wrap: wrap;
    align-items: flex-end;
    gap: var(--s-2);
    width: 100%;
    padding: var(--s-3);
    margin-top: var(--s-2);
    background: var(--bg-raised);
    border: 1px solid var(--line);
    border-radius: var(--r-md);
}

.cockpit-period__field {
    display: flex;
    flex-direction: column;
    gap: 2px;
    font-size: var(--text-xs);
    color: var(--text-mute);
}

.cockpit-period__field input {
    height: 32px;
    padding: 0 var(--s-2);
    border: 1px solid var(--line-strong);
    border-radius: var(--r-sm);
    background: var(--bg-app);
    color: var(--text);
    font-family: var(--font-ui);
    font-size: var(--text-sm);
}

.cockpit-period__field input:focus-visible {
    outline: 2px solid var(--accent);
    outline-offset: 1px;
    border-color: var(--accent);
}

@media (max-width: 767px) {
    .cockpit-period {
        overflow-x: auto;
        flex-wrap: nowrap;
        -webkit-overflow-scrolling: touch;
    }
}

/* ---------- Linha do dia (4 KPIs) ---------- */
.cockpit__primary {
    margin-bottom: 0;
}

/* KPI hero (GMV hoje) com sparkline embutida e padding maior */
.kpi--hero {
    padding: var(--s-5);
    gap: var(--s-2);
    position: relative;
    overflow: hidden;
}

.kpi--hero .kpi__value {
    font-size: var(--text-3xl);
    font-weight: var(--fw-bold);
}

@media (min-width: 1024px) {
    .kpi--hero .kpi__value {
        font-size: var(--text-4xl);
    }
}

.kpi--hero .kpi__hint {
    margin-top: var(--s-3);
    align-items: stretch;
}

.kpi--hero .kpi__hint .sparkline {
    width: 100%;
    height: 36px;
}

.kpi--hero .kpi__footer {
    border-top: 1px solid var(--line);
    padding-top: var(--s-3);
    margin-top: var(--s-2);
    font-size: var(--text-xs);
    color: var(--text-faint);
}

.kpi__accent-icon {
    position: absolute;
    top: var(--s-4);
    right: var(--s-4);
    color: var(--pix);
    opacity: 0.85;
}

/* ---------- Status bar à esquerda do KPI ---------- */
.kpi--with-status {
    position: relative;
    overflow: hidden;
}

.kpi--with-status::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    bottom: 0;
    width: 3px;
}

.kpi--with-status.kpi--status-ok::before { background: var(--ok); }
.kpi--with-status.kpi--status-warn::before { background: var(--warn); }
.kpi--with-status.kpi--status-bad::before { background: var(--bad); }

/* ---------- Grid principal: 1.4fr / 1fr ---------- */
.cockpit__columns {
    display: grid;
    gap: var(--s-5);
    grid-template-columns: 1fr;
    align-items: start;
}

@media (min-width: 1024px) {
    .cockpit__columns {
        grid-template-columns: minmax(0, 1.4fr) minmax(0, 1fr);
    }
}

.cockpit__col {
    display: flex;
    flex-direction: column;
    gap: var(--s-5);
    min-width: 0;
}

/* ---------- Card cockpit (variante sem padding interno padrão) ---------- */
.ck-card {
    background: var(--bg-raised);
    border: 1px solid var(--line);
    border-radius: var(--r-lg);
    box-shadow: var(--shadow-sm);
    display: flex;
    flex-direction: column;
    overflow: hidden;
}

.ck-card__header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--s-3);
    padding: var(--s-4) var(--s-5) var(--s-2);
}

.ck-card__title-block {
    min-width: 0;
}

.ck-card__eyebrow {
    font-size: var(--text-2xs);
    color: var(--text-faint);
    text-transform: uppercase;
    letter-spacing: 0.06em;
    font-weight: var(--fw-semibold);
    margin: 0 0 2px;
}

.ck-card__title {
    font-family: var(--font-display);
    font-size: var(--text-md);
    font-weight: var(--fw-semibold);
    color: var(--text);
    margin: 0;
}

.ck-card__action {
    flex-shrink: 0;
    font-size: var(--text-xs);
    color: var(--text-faint);
}

.ck-card__action a,
.ck-card__action button {
    color: var(--text-mute);
    text-decoration: none;
    font-size: var(--text-xs);
    font-weight: var(--fw-medium);
    background: transparent;
    border: 0;
    padding: var(--s-1) var(--s-2);
    border-radius: var(--r-sm);
    cursor: pointer;
    transition: background var(--t-fast) var(--ease-out);
}

.ck-card__action a:hover,
.ck-card__action button:hover {
    background: var(--bg-hover);
    color: var(--text);
}

.ck-card__body {
    padding: 0 var(--s-5) var(--s-4);
}

.ck-card__body--flush {
    padding: 0 0 var(--s-3);
}

/* ---------- Semáforo de saúde (2 colunas, 6 linhas) ---------- */
.semaphore {
    display: grid;
    grid-template-columns: 1fr;
    gap: 0;
}

@media (min-width: 768px) {
    .semaphore {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

.semaphore__item {
    display: flex;
    align-items: center;
    gap: var(--s-3);
    padding: var(--s-3) var(--s-5);
    border-top: 1px solid var(--line);
}

@media (min-width: 768px) {
    /* borda divisória entre as duas colunas */
    .semaphore__item:nth-child(odd) {
        border-right: 1px solid var(--line);
    }
}

.semaphore__bar {
    width: 4px;
    height: 38px;
    border-radius: 2px;
    flex-shrink: 0;
}

.semaphore__bar--ok { background: var(--ok); }
.semaphore__bar--warn { background: var(--warn); }
.semaphore__bar--bad { background: var(--bad); }

.semaphore__body {
    flex: 1;
    min-width: 0;
}

.semaphore__row {
    display: flex;
    align-items: baseline;
    justify-content: space-between;
    gap: var(--s-2);
}

.semaphore__label {
    font-size: var(--text-sm);
    color: var(--text-mute);
}

.semaphore__value {
    font-family: var(--font-mono);
    font-size: var(--text-lg);
    font-weight: var(--fw-semibold);
    color: var(--text);
    font-variant-numeric: tabular-nums;
}

.semaphore__meta {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-top: var(--s-1);
    gap: var(--s-2);
}

.semaphore__target {
    font-size: var(--text-2xs);
    color: var(--text-faint);
}

.semaphore__sparkline {
    flex-shrink: 0;
}

.semaphore__sparkline.is-ok   { color: var(--ok); }
.semaphore__sparkline.is-warn { color: var(--warn); }
.semaphore__sparkline.is-bad  { color: var(--bad); }

.semaphore__no-trend {
    font-size: var(--text-2xs);
    color: var(--text-faint);
    font-style: italic;
    cursor: help;
}

/* ---------- Deltas 7d (lista narrativa) ---------- */
.deltas7d {
    list-style: none;
    padding: 0 var(--s-5);
    margin: 0;
}

.deltas7d__item {
    display: flex;
    align-items: flex-start;
    gap: var(--s-3);
    padding: var(--s-3) 0;
    border-top: 1px solid var(--line);
}

.deltas7d__item:first-child {
    border-top: 0;
}

.deltas7d__dot {
    width: 6px;
    height: 6px;
    border-radius: 50%;
    margin-top: 8px;
    flex-shrink: 0;
}

.deltas7d__dot--good    { background: var(--ok); }
.deltas7d__dot--bad     { background: var(--bad); }
.deltas7d__dot--neutral { background: var(--text-mute); }

.deltas7d__text {
    flex: 1;
    font-size: var(--text-sm);
    color: var(--text);
    line-height: var(--lh-snug);
}

.deltas7d__action {
    background: transparent;
    border: 0;
    color: var(--text-faint);
    cursor: pointer;
    padding: var(--s-1);
    border-radius: var(--r-sm);
    flex-shrink: 0;
    transition: background var(--t-fast) var(--ease-out), color var(--t-fast) var(--ease-out);
}

.deltas7d__action:hover {
    background: var(--bg-hover);
    color: var(--text);
}

/* ---------- Filas em aberto (lista clicável) ---------- */
.queues {
    display: flex;
    flex-direction: column;
}

.queues__item {
    width: 100%;
    display: flex;
    align-items: center;
    gap: var(--s-3);
    padding: var(--s-3) var(--s-5);
    background: transparent;
    border: 0;
    border-top: 1px solid var(--line);
    cursor: pointer;
    text-align: left;
    text-decoration: none;
    color: inherit;
    transition: background var(--t-fast) var(--ease-out);
    min-height: 56px;
}

.queues__item:hover {
    background: var(--bg-hover);
}

.queues__icon {
    width: 36px;
    height: 36px;
    border-radius: var(--r-md);
    background: var(--bg-sunken);
    color: var(--text-mute);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}

.queues__body {
    flex: 1;
    min-width: 0;
}

.queues__label {
    font-size: var(--text-sm);
    font-weight: var(--fw-medium);
    color: var(--text);
}

.queues__sla {
    font-size: var(--text-2xs);
    color: var(--bad);
    margin-top: 2px;
}

.queues__count {
    font-family: var(--font-mono);
    font-size: var(--text-xl);
    font-weight: var(--fw-semibold);
    color: var(--text);
    font-variant-numeric: tabular-nums;
}

.queues__chevron {
    color: var(--text-faint);
    flex-shrink: 0;
}

/* ---------- Alertas operacionais ---------- */
.alerts {
    display: flex;
    flex-direction: column;
    gap: var(--s-3);
    padding: 0 var(--s-5) var(--s-4);
}

.alerts__item {
    display: flex;
    align-items: flex-start;
    gap: var(--s-3);
    padding: var(--s-3);
    border-radius: var(--r-md);
    border: 1px solid;
}

.alerts__item--bad {
    background: var(--bad-soft);
    border-color: var(--bad);
}

.alerts__item--warn {
    background: var(--warn-soft);
    border-color: var(--warn);
}

.alerts__icon {
    flex-shrink: 0;
    margin-top: 1px;
}

.alerts__item--bad .alerts__icon { color: var(--bad); }
.alerts__item--warn .alerts__icon { color: var(--warn); }

.alerts__body {
    flex: 1;
    min-width: 0;
}

.alerts__source {
    font-size: var(--text-2xs);
    text-transform: uppercase;
    letter-spacing: 0.04em;
    color: var(--text-mute);
    margin: 0 0 2px;
    font-weight: var(--fw-semibold);
}

.alerts__text {
    font-size: var(--text-sm);
    color: var(--text);
    margin: 0 0 var(--s-2);
}

/* ---------- Card Pix-share (Pagamento de hoje) ---------- */
.pix-share {
    display: flex;
    align-items: center;
    gap: var(--s-4);
    padding: 0 var(--s-5) var(--s-4);
}

.pix-share__icon {
    width: 64px;
    height: 64px;
    border-radius: var(--r-md);
    background: var(--pix-soft);
    color: var(--pix);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}

.pix-share__body {
    flex: 1;
    min-width: 0;
}

.pix-share__head {
    display: flex;
    align-items: baseline;
    gap: var(--s-2);
}

.pix-share__pct {
    font-family: var(--font-display);
    font-size: var(--text-2xl);
    font-weight: var(--fw-semibold);
    color: var(--text);
    font-variant-numeric: tabular-nums;
}

.pix-share__suffix {
    font-size: var(--text-sm);
    color: var(--text-mute);
}

.pix-share__bar {
    display: flex;
    height: 6px;
    border-radius: var(--r-pill);
    overflow: hidden;
    margin-top: var(--s-2);
    background: var(--bg-sunken);
}

.pix-share__bar-pix {
    background: var(--pix);
}

.pix-share__bar-card {
    background: var(--terra);
}

.pix-share__legend {
    display: flex;
    justify-content: space-between;
    margin-top: var(--s-1);
    font-size: var(--text-2xs);
    color: var(--text-faint);
    font-variant-numeric: tabular-nums;
}

/* ---------- Conteudo legado: page-header genérico permanece em outras páginas ---------- */

/* AdminBenchmarkBar quando colocado dentro do KpiCard usa a largura cheia */
.kpi__hint :deep(.admin-benchmark-bar) {
    width: 100%;
}

/* KPI usado como link no /conteudo: visual de card clicável */
.conteudo-kpi-link {
    display: flex;
    flex-direction: column;
    gap: var(--s-1);
    text-decoration: none;
    color: inherit;
    transition: border-color var(--t-fast) var(--ease-out),
                box-shadow var(--t-fast) var(--ease-out),
                transform var(--t-fast) var(--ease-out);
}

.conteudo-kpi-link:hover {
    border-color: var(--accent);
    box-shadow: var(--shadow-md);
    transform: translateY(-1px);
    color: inherit;
    text-decoration: none;
}

.conteudo-kpi-link:focus-visible {
    border-color: var(--accent);
    outline: 2px solid var(--accent);
    outline-offset: 2px;
}

/* Mobile: padding extra para bottom nav */
@media (max-width: 767px) {
    .cockpit {
        padding-bottom: calc(var(--bottomnav-h) + var(--s-5));
    }

    .ck-card__header,
    .ck-card__body,
    .deltas7d,
    .alerts,
    .pix-share,
    .semaphore__item,
    .queues__item {
        padding-left: var(--s-4);
        padding-right: var(--s-4);
    }
}

/* =====================================================
   Cockpit · Audience card (totais + cadastros do dia)
   ===================================================== */
.cockpit-audience {
    /* hereda ck-card padrão */
}

.cockpit-audience__grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 0;
    padding: 0 var(--s-5) var(--s-4);
}

@media (min-width: 768px) {
    .cockpit-audience__grid {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }
}

.cockpit-audience__cell {
    padding: var(--s-3) var(--s-4);
    border-top: 1px solid var(--line);
    display: flex;
    flex-direction: column;
    gap: 4px;
    min-width: 0;
}

@media (min-width: 768px) {
    .cockpit-audience__cell {
        border-top: 0;
        border-right: 1px solid var(--line);
        padding: var(--s-3) var(--s-4);
    }
    .cockpit-audience__cell:last-child {
        border-right: 0;
    }
}

.cockpit-audience__cell--accent {
    background: var(--accent-soft);
    border-radius: var(--r-sm);
}

@media (min-width: 768px) {
    .cockpit-audience__cell--accent {
        margin: var(--s-1) 0;
    }
}

.cockpit-audience__label {
    margin: 0;
    font-size: var(--text-2xs);
    color: var(--text-mute);
    text-transform: uppercase;
    letter-spacing: 0.06em;
    font-weight: var(--fw-semibold);
}

.cockpit-audience__cell--accent .cockpit-audience__label {
    color: var(--accent);
}

.cockpit-audience__value {
    font-family: var(--font-display);
    font-size: var(--text-3xl);
    font-weight: var(--fw-semibold);
    color: var(--text);
    margin: 0;
    line-height: var(--lh-tight);
    letter-spacing: -0.015em;
}

.cockpit-audience__cell--accent .cockpit-audience__value {
    color: var(--accent);
}

.cockpit-audience__hint {
    margin: 0;
    font-size: var(--text-xs);
    color: var(--text-mute);
    display: inline-flex;
    align-items: center;
    gap: 4px;
}

.cockpit-audience__hint--up {
    color: var(--ok);
}

.cockpit-audience__hint--down {
    color: var(--bad);
}
