/* ============================================================================
 * Constructo Analyst — Mobile (PWA) CSS
 * ----------------------------------------------------------------------------
 * MUITO ENXUTO POR DESIGN. O grosso das regras visuais vem de:
 *   1. tokens.css     — fonte da verdade (cores, espaçamento, tipografia, etc)
 *   2. Tailwind       — utility classes apontando pras CSS vars de tokens.css
 *
 * Este arquivo cobre só o que Tailwind não dá fácil:
 *   - Safe-area helpers concretos (Tailwind tem `pt-safe-top` mas é
 *     `padding-top: env(...)` — aqui mantemos como fallback)
 *   - Scroll com momentum em iOS (web não tem utility pra isso)
 *   - Reset específico de mobile (tap-highlight, font-size em landscape)
 *   - Animação "pulse pensando" (já no Tailwind config — duplicada aqui pra
 *     que componentes que não passem pelo Tailwind purge ainda funcionem)
 *
 * Versão: 1.0 (Passo 1 do plano PWA)
 * Carregado DEPOIS de tokens.css e DEPOIS do output do Tailwind.
 * ============================================================================ */


/* ----------------------------------------------------------------------------
 * Safe areas — utilitários que se aplicam a qualquer container
 * tokens.css já define --safe-{top,right,bottom,left} via env(safe-area-inset-*)
 * ---------------------------------------------------------------------------- */
.safe-top    { padding-top:    var(--safe-top); }
.safe-right  { padding-right:  var(--safe-right); }
.safe-bottom { padding-bottom: var(--safe-bottom); }
.safe-left   { padding-left:   var(--safe-left); }
.safe-x      { padding-left: var(--safe-left); padding-right: var(--safe-right); }


/* ----------------------------------------------------------------------------
 * Scroll com momentum em iOS — sente nativo
 * (já existe em tokens.css; redeclarado aqui pra garantia)
 * ---------------------------------------------------------------------------- */
.scroll-momentum {
    -webkit-overflow-scrolling: touch;
    overscroll-behavior: contain;
}


/* ----------------------------------------------------------------------------
 * App shell — estrutura do PWA (app bar fixa + main scroll + bottom nav fixa)
 *
 * O <main> é a única área que rola; app bar e bottom nav ficam grudados.
 * Isso reproduz comportamento de app nativo (chrome não some no scroll).
 * ---------------------------------------------------------------------------- */
.app-shell {
    display: flex;
    flex-direction: column;
    min-height: 100vh;
    /* Fallback pra iOS Safari onde 100vh inclui chrome do browser */
    min-height: 100dvh;
}

.app-shell-main {
    flex: 1 1 auto;
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
    overscroll-behavior: contain;
    /* Espaço pra não ficar atrás do bottom nav. Sem isso o último item
       da lista fica ocluído pela navegação. */
    padding-bottom: calc(var(--bottom-nav-height) + var(--safe-bottom) + 8px);
}


/* ----------------------------------------------------------------------------
 * Touch — desliga highlight azul padrão do iOS, ativa :active visual
 * ---------------------------------------------------------------------------- */
button, a, [role="button"] {
    -webkit-tap-highlight-color: transparent;
    touch-action: manipulation;   /* sem delay de 300ms em duplo-tap */
}

/* :active pra mobile (replace de hover) — feedback tátil universal */
.touchable:active {
    transform: scale(0.97);
    transition: transform 100ms var(--ease-out);
}


/* ----------------------------------------------------------------------------
 * Bottom nav (v2 — sessão 12): monocromática estrita estilo Linear / Notion.
 *
 * Item ativo se distingue APENAS por contraste de cor (texto/ícone forte).
 * Sem pílula, sem círculo, sem sublinhado — pura hierarquia tipográfica.
 *
 * O item ocupa flex:1 dentro de uma linha de altura fixa (--bottom-nav-height
 * = 56px) + safe-area-inset-bottom embaixo. Touch target da linha inteira.
 * ---------------------------------------------------------------------------- */
.krp-bottom-nav {
    position: fixed;
    bottom: 0;
    left: 0;
    right: 0;
    z-index: var(--z-bottom-nav);
    display: flex;
    align-items: stretch;
    height: var(--bottom-nav-height);
    background: var(--color-bg-card);
    border-top: 1px solid var(--color-border-subtle);
    padding-bottom: var(--safe-bottom);
}

.krp-nav-item {
    flex: 1 1 0;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 4px;
    text-decoration: none;
    color: var(--color-text-muted);   /* inativo = cinza */
    transition: color 150ms var(--ease-out);
}

.krp-nav-item.is-active {
    color: var(--color-text);          /* ativo = texto forte (único realce) */
}

.krp-nav-item:focus-visible {
    outline: none;
    box-shadow: var(--shadow-focus);
    border-radius: var(--radius-sm);
}

.krp-nav-label {
    font-family: var(--font-family-sans);
    font-size: 11px;
    font-weight: var(--font-weight-medium);
    line-height: 1;
    letter-spacing: -0.01em;
    text-decoration: none;   /* explicit — sem sublinhado */
}


/* ----------------------------------------------------------------------------
 * Pulse "Pensando..." — usado SEMPRE que IA estiver processando
 * Tailwind config também tem `animate-pulse-pensando`; redeclarado pra que
 * funcione mesmo se Tailwind purge não pegar (componentes futuros).
 * ---------------------------------------------------------------------------- */
@keyframes pulse-pensando {
    0%, 80%, 100% { opacity: 0.3; }
    40%           { opacity: 1.0; }
}

.pensando-dot {
    width: 6px;
    height: 6px;
    border-radius: 50%;
    background: var(--color-ai-accent);
    animation: pulse-pensando 1.4s ease-in-out infinite;
}
.pensando-dot:nth-child(2) { animation-delay: 0.2s; }
.pensando-dot:nth-child(3) { animation-delay: 0.4s; }


/* ----------------------------------------------------------------------------
 * Loading bar topo — shimmer sutil 4px (mesmo padrão do desktop CustosIa)
 * Aparece em x-show="carregando"
 * ---------------------------------------------------------------------------- */
.loading-bar {
    position: fixed;
    top: var(--safe-top);
    left: 0;
    right: 0;
    height: 3px;
    background: linear-gradient(
        90deg,
        var(--color-bg-hover) 0%,
        var(--color-text-muted) 50%,
        var(--color-bg-hover) 100%
    );
    background-size: 200% 100%;
    animation: shimmer 1.6s ease-in-out infinite;
    z-index: var(--z-sticky);
}

@keyframes shimmer {
    0%   { background-position: 200% 0; }
    100% { background-position: -200% 0; }
}


/* ----------------------------------------------------------------------------
 * Bottom sheet — modais que surgem de baixo (mais nativo que centro no mobile)
 * Estrutura é Tailwind/Alpine; aqui só animação de entrada.
 * ---------------------------------------------------------------------------- */
@keyframes slide-up-sheet {
    0%   { transform: translateY(100%); }
    100% { transform: translateY(0); }
}
.sheet-enter {
    animation: slide-up-sheet var(--duration-normal) var(--ease-out);
}


/* ----------------------------------------------------------------------------
 * Trial banner — sticky abaixo do app bar. Cor por urgência. CTA "Renovar".
 * ---------------------------------------------------------------------------- */
.krp-trial-banner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    padding: 8px 16px;
    font-size: 13px;
    line-height: 1.3;
    border-bottom: 1px solid var(--color-border-subtle);
}
.krp-trial-normal {
    background: var(--color-info-bg);
    color: var(--color-info);
}
.krp-trial-atencao {
    background: var(--color-warning-bg);
    color: var(--color-warning);
}
.krp-trial-urgente {
    background: var(--color-danger-bg);
    color: var(--color-danger);
    font-weight: var(--font-weight-medium);
}
.krp-trial-cta {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 6px 12px;
    background: var(--color-primary);
    color: var(--color-primary-text);
    text-decoration: none;
    font-weight: var(--font-weight-medium);
    font-size: 13px;
    border-radius: var(--radius-md);
    white-space: nowrap;
    flex-shrink: 0;
}


/* ----------------------------------------------------------------------------
 * Cards do dashboard mobile (KPIs do Início) — grid 2x2 monocromático
 * ---------------------------------------------------------------------------- */
.krp-kpi-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 12px;
}
.krp-kpi-card {
    background: var(--color-bg-card);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    padding: 16px;
    display: flex;
    flex-direction: column;
    gap: 8px;
}
.krp-kpi-card-icon {
    color: var(--color-text-muted);
}
.krp-kpi-card-label {
    font-size: 12px;
    color: var(--color-text-muted);
    font-weight: var(--font-weight-medium);
    text-transform: uppercase;
    letter-spacing: var(--letter-spacing-caps);
}
.krp-kpi-card-value {
    font-size: 28px;
    font-weight: var(--font-weight-semibold);
    color: var(--color-text);
    line-height: 1;
    letter-spacing: -0.02em;
}


/* ----------------------------------------------------------------------------
 * Lista — list_item touch-friendly (≥56px) com avatar/ícone + texto
 * Reusada em: feed do Início, lista de serviços, alertas, registros, configs
 * ---------------------------------------------------------------------------- */
.krp-list {
    display: flex;
    flex-direction: column;
    background: var(--color-bg-card);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    overflow: hidden;
}
.krp-list-item {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 14px 16px;
    min-height: 56px;
    color: var(--color-text);
    text-decoration: none;
    border-bottom: 1px solid var(--color-border-subtle);
}
.krp-list-item:last-child { border-bottom: none; }
.krp-list-item-icon {
    flex-shrink: 0;
    width: 36px;
    height: 36px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--color-text-muted);
    background: var(--color-bg-hover);
    border-radius: var(--radius-full);
}
.krp-list-item-body {
    flex: 1 1 auto;
    min-width: 0;
}
.krp-list-item-title {
    font-size: 14px;
    font-weight: var(--font-weight-medium);
    color: var(--color-text);
    line-height: 1.3;
}
.krp-list-item-subtitle {
    font-size: 12px;
    color: var(--color-text-muted);
    margin-top: 2px;
    line-height: 1.3;
}
.krp-list-item-chevron {
    flex-shrink: 0;
    color: var(--color-text-subtle);
}


/* ----------------------------------------------------------------------------
 * Section header — título de seção com letter-spacing-caps (padrão da plataforma)
 * ---------------------------------------------------------------------------- */
.krp-section-header {
    font-size: 11px;
    font-weight: var(--font-weight-semibold);
    color: var(--color-text-muted);
    text-transform: uppercase;
    letter-spacing: var(--letter-spacing-caps);
    margin: 24px 16px 8px;
}


/* ----------------------------------------------------------------------------
 * Botão de logout em destaque — vermelho, full-width, dentro de Configurações
 * ---------------------------------------------------------------------------- */
.krp-btn-logout {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    width: 100%;
    padding: 14px 16px;
    background: var(--color-bg-card);
    color: var(--color-danger);
    border: 1px solid var(--color-danger-border);
    border-radius: var(--radius-md);
    font-size: 15px;
    font-weight: var(--font-weight-medium);
    text-decoration: none;
}
.krp-btn-logout:active {
    background: var(--color-danger-bg);
}


/* ----------------------------------------------------------------------------
 * ⚠ TESTE — Dashboard mobile (sub-fase 5A.3, não-definitivo)
 *
 * Widgets empilhados em 1 coluna. Reusa tokens do projeto (--color-*).
 * Quando virar definitivo, mover bloco pra arquivo próprio dashboard-mobile.css
 * carregado só na rota /mobile/dashboards/* via condicional no layout.
 * ---------------------------------------------------------------------------- */
.krp-mobile-dash-grid {
    display: flex;
    flex-direction: column;
    gap: 12px;
}
.krp-mobile-dash-card {
    background: var(--color-bg-card);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    padding: 16px;
    display: flex;
    flex-direction: column;
    gap: 12px;
    transition: border-color 0.15s ease;
    /* Sub-fase 5C.2 — flip overlay com efeito 3D na transição */
    position: relative;
    perspective: 1500px;
}

/* Back: overlay POR CIMA do card. Aparece via x-show Alpine */
.krp-mobile-dash-flip-back {
    position: absolute;
    inset: 0;
    padding: 16px 18px;
    display: flex;
    flex-direction: column;
    gap: 12px;
    background: var(--color-bg-card, #232323);
    color: var(--color-text, inherit);
    border-radius: inherit;
    z-index: 20;
    transform-origin: right center;
    box-shadow: var(--shadow-md, 0 4px 12px rgba(0, 0, 0, 0.15));
}

/* x-transition Alpine — efeito 3D rotateY parcial */
.krp-mobile-dash-flip-enter {
    transition: transform 500ms cubic-bezier(.55, 0, .15, 1), opacity 400ms;
}
.krp-mobile-dash-flip-enter-start { transform: rotateY(-90deg); opacity: 0; }
.krp-mobile-dash-flip-enter-end   { transform: rotateY(0deg);   opacity: 1; }
.krp-mobile-dash-flip-leave {
    transition: transform 400ms cubic-bezier(.55, 0, .15, 1), opacity 350ms;
}
.krp-mobile-dash-flip-leave-start { transform: rotateY(0deg);  opacity: 1; }
.krp-mobile-dash-flip-leave-end   { transform: rotateY(90deg); opacity: 0; }

/* Verso — header com badge KPI + título bold + botão X */
.krp-mobile-dash-flip-back-header {
    display: flex;
    align-items: center;
    gap: 10px;
    padding-bottom: 12px;
    border-bottom: 1px solid color-mix(in srgb, var(--color-text-muted, #888) 18%, transparent);
}
.krp-mobile-dash-flip-back-header .krp-mobile-dash-cat {
    flex-shrink: 0;
}
.krp-mobile-dash-flip-back-header strong {
    flex: 1;
    font-size: 15px;
    font-weight: 700;
    letter-spacing: -0.01em;
    color: var(--color-text, inherit);
}

/* Body — descrição com tipografia premium + scrollbar fino */
.krp-mobile-dash-flip-back-body {
    flex: 1;
    overflow-y: auto;
    overflow-x: hidden;
    font-size: 13px;
    line-height: 1.6;
    color: var(--color-text-muted, #A8A8A6);
    padding-right: 6px;
    scrollbar-width: thin;
    scrollbar-color: color-mix(in srgb, var(--color-text-muted, #888) 25%, transparent) transparent;
}
.krp-mobile-dash-flip-back-body p { margin: 0; }
.krp-mobile-dash-flip-back-body p + p { margin-top: 10px; }
.krp-mobile-dash-flip-back-body::-webkit-scrollbar { width: 5px; }
.krp-mobile-dash-flip-back-body::-webkit-scrollbar-track { background: transparent; }
.krp-mobile-dash-flip-back-body::-webkit-scrollbar-thumb {
    background: color-mix(in srgb, var(--color-text-muted, #888) 25%, transparent);
    border-radius: 3px;
}

/* Botão "i" / "X" — tap-target ≥28px (touch-friendly) */
.krp-mobile-dash-flip-toggle {
    background: transparent;
    border: 0;
    cursor: pointer;
    padding: 6px;
    min-width: 28px;
    min-height: 28px;
    color: var(--color-text-muted);
    opacity: 0.55;
    border-radius: 4px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    transition: opacity 0.15s, color 0.15s;
}
.krp-mobile-dash-flip-toggle:active {
    opacity: 1;
    color: var(--cor-primaria, #4a90e2);
}
.krp-mobile-dash-card.is-stale {
    border-color: color-mix(in srgb, #d97706 50%, var(--color-border));
    background: color-mix(in srgb, #d97706 2%, var(--color-bg-card));
}
.krp-mobile-dash-card-header {
    display: flex;
    align-items: center;
    gap: 8px;
    min-height: 24px;
}
.krp-mobile-dash-cat {
    font-size: 10px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    padding: 2px 7px;
    border-radius: 4px;
    border: 1px solid transparent;
    flex-shrink: 0;
}
/* Sub-fase 5C.4 — TODOS os badges de categoria em escala de cinza neutra.
   Cor só nos deltas verde/vermelho dos valores. */
.krp-mobile-dash-cat[data-cat="kpi"],
.krp-mobile-dash-cat[data-cat="chart"],
.krp-mobile-dash-cat[data-cat="ia"],
.krp-mobile-dash-cat[data-cat="tabela"],
.krp-mobile-dash-cat[data-cat="outro"] {
    background: color-mix(in srgb, var(--color-text-muted, #888) 14%, transparent);
    color: var(--color-text-muted, #888);
    border-color: transparent;
}

/* ── Etiqueta (tag) por widget (db/139) — selo configurável na aba Visual. ────
   Mesmo formato do badge de categoria; default neutro; cor opcional via token. */
.krp-mobile-dash-etiqueta {
    font-size: 10px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    padding: 2px 7px;
    border-radius: 4px;
    border: 1px solid transparent;
    flex-shrink: 0;
    background: color-mix(in srgb, var(--color-text-muted, #888) 14%, transparent);
    color: var(--color-text-muted, #888);
}
.krp-mobile-dash-etiqueta--info    { background: color-mix(in srgb, var(--cor-info) 14%, transparent);    color: var(--cor-info); }
.krp-mobile-dash-etiqueta--sucesso { background: color-mix(in srgb, var(--cor-sucesso) 14%, transparent); color: var(--cor-sucesso); }
/* Âmbar puro é ilegível no claro (~2.3:1) — escurece o texto rumo ao --color-text (lição s72). */
.krp-mobile-dash-etiqueta--aviso   { background: color-mix(in srgb, var(--cor-aviso) 20%, transparent);   color: color-mix(in srgb, var(--cor-aviso) 60%, var(--color-text)); }
.krp-mobile-dash-etiqueta--erro    { background: color-mix(in srgb, var(--cor-erro) 14%, transparent);    color: var(--cor-erro); }

/* Ajuda "Como ler" (botão "?") — reusa o overlay do flip-back; só a tipografia do tutorial. */
.krp-mobile-ajuda-curta { font-weight: 600; color: var(--color-text, inherit); margin: 0 0 10px; }
.krp-mobile-ajuda-tutorial h4 { font-size: 13px; font-weight: 700; margin: 12px 0 4px; color: var(--color-text, inherit); }
.krp-mobile-ajuda-tutorial p  { margin: 0 0 8px; }
.krp-mobile-ajuda-tutorial ul, .krp-mobile-ajuda-tutorial ol { margin: 0 0 8px; padding-left: 18px; }
.krp-mobile-ajuda-tutorial li { margin: 0 0 5px; }

.krp-mobile-dash-titulo {
    flex: 1;
    font-size: 14px;
    font-weight: var(--font-weight-semibold);
    color: var(--color-text);
    line-height: 1.3;
}
.krp-mobile-dash-stale-badge {
    color: #d97706;
    font-size: 16px;
    line-height: 1;
}

/* KPI body */
.krp-mobile-dash-kpi {
    display: flex;
    flex-direction: column;
    gap: 4px;
    padding: 4px 0;
}
.krp-mobile-dash-kpi-label {
    font-size: 11px;
    font-weight: 600;
    color: var(--color-text-muted);
    text-transform: uppercase;
    letter-spacing: 0.5px;
}
.krp-mobile-dash-kpi-valor {
    font-size: 28px;
    font-weight: var(--font-weight-semibold);
    color: var(--color-text);
    line-height: 1.1;
    font-variant-numeric: tabular-nums;
    letter-spacing: -0.01em;
}
.krp-mobile-dash-kpi-variacao {
    font-size: 13px;
    font-weight: 600;
    margin-top: 2px;
}
.krp-mobile-dash-kpi-variacao[data-positivo="sim"] { color: #16a34a; }
.krp-mobile-dash-kpi-variacao[data-positivo="nao"] { color: #dc2626; }

/* Goal — barra de progresso */
.krp-mobile-dash-progress {
    margin-top: 8px;
    height: 6px;
    background: var(--color-border);
    border-radius: 3px;
    overflow: hidden;
}
.krp-mobile-dash-progress-bar {
    height: 100%;
    background: var(--cor-primaria, #4a90e2);
    transition: width 0.4s ease;
}

/* Placeholder pra widgets sem dado / sem template portado */
.krp-mobile-dash-placeholder {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 8px;
    padding: 24px 12px;
    color: var(--color-text-muted);
    text-align: center;
    font-size: 13px;
}
.krp-mobile-dash-placeholder svg {
    opacity: 0.5;
}

/* Footer com badge da fonte + timestamp (5A.4 patch — espelho do desktop).
   Border adaptativa via color-mix do texto-muted: sutil em ambos os temas. */
.krp-mobile-dash-card-footer {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 11px;
    color: var(--color-text-muted);
    border-top: 1px solid color-mix(in srgb, var(--color-text-muted, #888) 14%, transparent);
    padding-top: 8px;
    margin-top: 4px;
}
.krp-mobile-fonte-badge {
    font-size: 9px;
    font-weight: 700;
    letter-spacing: 0.06em;
    padding: 2px 6px;
    border-radius: 3px;
    text-transform: uppercase;
    line-height: 1;
}
/* Sub-fase 5C.4 — LIVE/DIÁRIO em escala de cinza. Intensidade diferencia:
   LIVE mais "vivo" (texto principal), DIÁRIO mais discreto (texto muted). */
.krp-mobile-fonte-badge--live {
    background: color-mix(in srgb, var(--color-text-muted, #888) 22%, transparent);
    color: var(--color-text, inherit);
}
.krp-mobile-fonte-badge--diario {
    background: color-mix(in srgb, var(--color-text-muted, #888) 14%, transparent);
    color: var(--color-text-muted, #888);
}
.krp-mobile-fonte-data {
    font-variant-numeric: tabular-nums;
}

/* ============================================================================
 * KPI Comparativo — schema novo da sessão 29 (coluna_atual + coluna_anterior + delta)
 * Layout: grid 2 colunas dentro do card mobile + delta abaixo.
 * ============================================================================ */
.krp-mobile-dash-kpi-comp {
    display: flex;
    flex-direction: column;
    gap: 8px;
    padding: 4px 0;
}
.krp-mobile-dash-kpi-comp-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 16px;
    align-items: end;
}
.krp-mobile-dash-kpi-comp-cell {
    display: flex;
    flex-direction: column;
    gap: 4px;
    min-width: 0;  /* permite truncate em flex/grid children */
}
.krp-mobile-dash-kpi-comp-cell-sec {
    border-left: 1px solid color-mix(in srgb, var(--color-text-muted, #888) 14%, transparent);
    padding-left: 16px;
}
.krp-mobile-dash-kpi-comp-cell .krp-mobile-dash-kpi-label {
    /* permite quebra em 2 linhas antes do truncate (resolve "MÉDIA DIÁRIA DO M..." cortado) */
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    line-clamp: 2;
    overflow: hidden;
    line-height: 1.2;
    overflow-wrap: anywhere;
}
.krp-mobile-dash-kpi-valor-md {
    font-size: 22px;
    font-weight: var(--font-weight-semibold);
    color: var(--color-text);
    line-height: 1.1;
    font-variant-numeric: tabular-nums;
}
.krp-mobile-dash-kpi-valor-sm {
    font-size: 16px;
    color: var(--color-text-muted);
    font-variant-numeric: tabular-nums;
    line-height: 1.1;
}
.krp-mobile-dash-kpi-delta {
    font-size: 13px;
    font-weight: 600;
    margin-top: 2px;
    font-variant-numeric: tabular-nums;
}
.krp-mobile-dash-kpi-delta[data-positivo="sim"] { color: #16a34a; }
.krp-mobile-dash-kpi-delta[data-positivo="nao"] { color: #dc2626; }


/* ----------------------------------------------------------------------------
 * x-cloak — esconde elementos Alpine até hidratar (evita flash de conteúdo)
 * Tailwind não tem isso nativo; é hack universal Alpine.
 * ---------------------------------------------------------------------------- */
[x-cloak] { display: none !important; }

/* ============================================================================
 * SININHO DE NOTIFICAÇÕES (app_bar mobile) — sessão 46 (2026-05-21)
 * Espelho monocromático do bell do desktop, com badge de contador.
 * Cores via var() do tokens.css — respeita dark/light automaticamente.
 * ============================================================================ */

.krp-mobile-bell {
    position: relative;
    display: inline-flex;
}

.krp-mobile-bell-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 36px;
    height: 36px;
    border-radius: 50%;
    background: transparent;
    color: var(--color-text);
    border: none;
    cursor: pointer;
    position: relative;
    transition: background-color 0.15s ease, color 0.15s ease;
}
.krp-mobile-bell-btn:hover {
    background-color: var(--color-bg-hover);
}
.krp-mobile-bell-btn.has-alert {
    color: var(--color-accent);
}

.krp-mobile-bell-count {
    position: absolute;
    top: 2px;
    right: 2px;
    min-width: 18px;
    height: 18px;
    padding: 0 5px;
    /* Sessão 27 (2026-05-28): badge vermelho clássico de notificação,
       legível em dark e light. Antes usava --color-accent (verde) com
       --color-bg-card (claro) — contraste ruim no dark mode. */
    background-color: #DC2626;
    color: #FFFFFF;
    border-radius: 999px;
    font-size: 11px;
    font-weight: 700;
    line-height: 18px;
    text-align: center;
    box-shadow: 0 0 0 2px var(--color-bg-card);
    text-shadow: 0 1px 1px rgba(0, 0, 0, 0.4);
}

/* Dropdown — fixed pra escapar overflow do header sticky */
.krp-mobile-bell-dropdown {
    position: fixed;
    top: calc(var(--h-app-bar, 56px) + var(--safe-area-inset-top, 0px) + 4px);
    right: 8px;
    width: min(320px, calc(100vw - 16px));
    max-height: calc(100vh - var(--h-app-bar, 56px) - 32px);
    overflow-y: auto;
    background-color: var(--color-bg-card);
    border: 1px solid var(--color-border-subtle);
    border-radius: 12px;
    box-shadow: 0 12px 32px rgba(0,0,0,0.25);
    z-index: calc(var(--z-app-bar, 1300) + 1);
    overscroll-behavior: contain;
}

.krp-mobile-bell-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 12px 14px;
    border-bottom: 1px solid var(--color-border-subtle);
    font-size: 13px;
    color: var(--color-text);
}
.krp-mobile-bell-count-label {
    font-size: 11px;
    color: var(--color-text-muted);
}

.krp-mobile-bell-list {
    display: flex;
    flex-direction: column;
}

.krp-mobile-bell-item {
    display: block;
    padding: 12px 14px;
    border-bottom: 1px solid var(--color-border-subtle);
    color: var(--color-text);
    text-decoration: none;
    transition: background-color 0.15s ease;
}
.krp-mobile-bell-item:hover {
    background-color: var(--color-bg-hover);
}
.krp-mobile-bell-item:last-child {
    border-bottom: none;
}

.krp-mobile-bell-item-tipo {
    font-size: 10px;
    font-weight: 600;
    color: var(--color-accent);
    text-transform: uppercase;
    letter-spacing: 0.05em;
}
.krp-mobile-bell-item-titulo {
    font-size: 13px;
    margin-top: 3px;
    color: var(--color-text);
    line-height: 1.35;
}
.krp-mobile-bell-item-data {
    font-size: 11px;
    color: var(--color-text-muted);
    margin-top: 3px;
}

.krp-mobile-bell-empty {
    padding: 24px 14px;
    text-align: center;
    color: var(--color-text-muted);
    font-size: 12px;
}

/* Transition slide-down (Alpine) */
.krp-mobile-bell-enter {
    transition: opacity 0.18s ease, transform 0.18s ease;
}
.krp-mobile-bell-enter-start {
    opacity: 0;
    transform: translateY(-6px);
}
.krp-mobile-bell-enter-end {
    opacity: 1;
    transform: translateY(0);
}

/* ──────────────────────────────────────────────────────────────────
   Filtro 'busca' (autocomplete) — PWA (sessão 58).
   Versão mobile-friendly do .busca-* do desktop:
     • Dropdown ocupa 100% da largura do form-group (não absolute) →
       não corta em telas estreitas e não conflita com scroll do body.
     • Tap area 48px+ em cada sugestão.
     • Estados visuais (carregando, sem resultado) reusam vars do tema.
   ────────────────────────────────────────────────────────────────── */
.mob-busca-wrap {
    position: relative;
    display: block;
    width: 100%;
}
.mob-busca-input-wrap {
    position: relative;
    display: block;
    width: 100%;
}
.mob-busca-clear {
    position: absolute;
    right: 8px;
    top: 50%;
    transform: translateY(-50%);
    width: 32px;
    height: 32px;
    background: transparent;
    border: none;
    color: var(--color-text-muted);
    cursor: pointer;
    font-size: 22px;
    line-height: 1;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 0;
}
.mob-busca-clear:active {
    background: color-mix(in srgb, var(--color-text) 8%, transparent);
    color: var(--color-text);
}
.mob-busca-dropdown {
    margin-top: 6px;
    width: 100%;
    max-height: 320px;
    overflow-y: auto;
    background: var(--color-bg-elevated);
    border: 1px solid var(--color-border);
    border-radius: 10px;
    box-shadow: 0 8px 24px color-mix(in srgb, var(--color-text) 12%, transparent);
    -webkit-overflow-scrolling: touch;
}
.mob-busca-item {
    padding: 14px 16px;
    min-height: 48px;
    display: flex;
    align-items: center;
    font-size: 15px;
    color: var(--color-text);
    border-bottom: 1px solid var(--color-border-subtle);
    cursor: pointer;
    user-select: none;
}
.mob-busca-item:last-child {
    border-bottom: none;
}
.mob-busca-item:active {
    background: color-mix(in srgb, var(--color-text) 8%, transparent);
}
.mob-busca-info {
    color: var(--color-text-muted);
    font-style: italic;
    cursor: default;
}
.mob-busca-info:active {
    background: transparent;
}

/* ══════════════════════════════════════════════════════════════════════
   Toolbar de ações + análise IA + bottom-sheet de e-mail no resultado (#37)
   Catálogo data-driven (krpconnect.acoes_catalogo, interface=pwa). Só tokens.
   ══════════════════════════════════════════════════════════════════════ */
.mob-acoes-toolbar {
    display: flex;
    gap: 8px;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    padding: 4px 0 10px;
    margin-bottom: 4px;
    border-bottom: 1px solid var(--color-border-subtle);
    scrollbar-width: none;
}
.mob-acoes-toolbar::-webkit-scrollbar { display: none; }
.mob-acao-btn {
    flex: 0 0 auto;
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 8px 12px;
    border: 1px solid var(--color-border);
    border-radius: 999px;
    background: var(--color-bg-card);
    color: var(--color-text);
    font-size: 13px;
    font-weight: 500;
    cursor: pointer;
    white-space: nowrap;
}
.mob-acao-btn:active { background: var(--color-bg-hover); }
.mob-acao-btn.is-disabled,
.mob-acao-btn:disabled { opacity: 0.45; cursor: not-allowed; }
.mob-acao-ico { display: inline-flex; color: var(--color-text-muted); }
.mob-acao-label { line-height: 1; }

.mob-analise-loading {
    margin-top: 14px;
    padding: 14px 16px;
    border: 1px solid var(--color-border);
    border-radius: 12px;
    background: var(--color-bg-card);
    color: var(--color-text-muted);
    font-size: 14px;
}
.mob-analise-card {
    margin-top: 14px;
    padding: 16px;
    border: 1px solid var(--color-border);
    border-radius: 12px;
    background: var(--color-bg-card);
}
.mob-analise-title {
    font-size: 14px;
    font-weight: 600;
    color: var(--color-text);
    margin-bottom: 8px;
}
.mob-analise-body { font-size: 14px; line-height: 1.55; color: var(--color-text); }
.mob-analise-body p { margin: 0 0 10px; }
.mob-analise-body ul, .mob-analise-body ol { margin: 0 0 10px; padding-left: 20px; }

.mob-sheet-overlay {
    position: fixed;
    inset: 0;
    z-index: 1000;
    background: color-mix(in srgb, var(--color-text) 45%, transparent);
    display: flex;
    align-items: flex-end;
    justify-content: center;
}
.mob-sheet {
    width: 100%;
    max-width: 560px;
    background: var(--color-bg-card);
    border-radius: 18px 18px 0 0;
    padding: 10px 18px calc(20px + env(safe-area-inset-bottom));
    box-shadow: 0 -8px 32px color-mix(in srgb, var(--color-text) 18%, transparent);
}
.mob-sheet-handle {
    width: 40px; height: 4px;
    border-radius: 999px;
    background: var(--color-border);
    margin: 0 auto 14px;
}
.mob-sheet-title { font-size: 16px; font-weight: 600; color: var(--color-text); margin-bottom: 6px; }
.mob-sheet-label { display: block; font-size: 12px; font-weight: 600; color: var(--color-text-muted); margin-bottom: 6px; }
.mob-sheet-input {
    width: 100%;
    box-sizing: border-box;
    padding: 12px;
    font-size: 16px;
    border: 1px solid var(--color-border);
    border-radius: 10px;
    background: var(--color-bg-card);
    color: var(--color-text);
    margin-bottom: 4px;
}
.mob-sheet-actions { display: flex; gap: 10px; margin-top: 16px; }
.mob-sheet-btn {
    flex: 1;
    padding: 13px;
    border-radius: 10px;
    font-size: 15px;
    font-weight: 600;
    border: 1px solid var(--color-border);
    cursor: pointer;
}
.mob-sheet-btn--ghost   { background: var(--color-bg-card); color: var(--color-text); }
.mob-sheet-btn--primary { background: var(--color-primary); color: var(--color-primary-text); border-color: var(--color-primary); }
.mob-sheet-btn:disabled { opacity: 0.55; cursor: not-allowed; }
