html, body {
    margin: 0;
    padding: 0;
    font-family: 'Roboto', sans-serif;
    scroll-behavior: smooth;
}

a, .btn-link {
    color: #4f46e5;
}

/* ---------- Tela de carregamento inicial ---------- */
.app-loading {
    position: absolute;
    inset: 0;
}

.loading-progress {
    position: absolute;
    display: block;
    width: 8rem;
    height: 8rem;
    inset: 30vh 0 auto 0;
    margin: 0 auto;
}

    .loading-progress circle {
        fill: none;
        stroke: #e6e6f7;
        stroke-width: 0.6rem;
        transform-origin: 50% 50%;
        transform: rotate(-90deg);
    }

        .loading-progress circle:last-child {
            stroke: #4f46e5;
            stroke-dasharray: calc(3.141 * var(--blazor-load-percentage, 0%) * 0.8), 500%;
            transition: stroke-dasharray 0.05s ease-in-out;
        }

.loading-progress-text {
    position: absolute;
    text-align: center;
    font-weight: bold;
    color: #4f46e5;
    inset: calc(30vh + 3.25rem) 0 auto 0.2rem;
}

    .loading-progress-text:after {
        content: var(--blazor-load-percentage-text, "Carregando...");
    }

/* ---------- Erro do Blazor ---------- */
#blazor-error-ui {
    color-scheme: light only;
    background: lightyellow;
    bottom: 0;
    box-shadow: 0 -1px 2px rgba(0, 0, 0, 0.2);
    box-sizing: border-box;
    display: none;
    left: 0;
    padding: 0.6rem 1.25rem 0.7rem 1.25rem;
    position: fixed;
    width: 100%;
    z-index: 1000;
}

    #blazor-error-ui .dismiss {
        cursor: pointer;
        position: absolute;
        right: 0.75rem;
        top: 0.5rem;
    }

.blazor-error-boundary {
    background: #b32121;
    padding: 1rem;
    color: white;
}

    .blazor-error-boundary::after {
        content: "Ocorreu um erro.";
    }

/* ============================================================
   Telas de autenticação (login e cadastro) — mobile-first
   ------------------------------------------------------------
   O card é centralizado quando há espaço, mas usa margin:auto
   (em vez de align-items:center) para que, quando o conteúdo
   for mais alto que a viewport — caso do cadastro —, o topo não
   seja cortado nem fique sob o header: ele encosta no topo e a
   página rola normalmente.
   ============================================================ */
.auth-shell {
    min-height: calc(100dvh - var(--mud-appbar-height));
    display: flex;
    padding: 24px 16px;
    box-sizing: border-box;
}

.auth-card {
    width: 100%;
    margin: auto;
    border-radius: 18px;
}

/* A partir de telas pequenas, mais respiro lateral/vertical. */
@media (min-width: 600px) {
    .auth-shell {
        padding: 40px 24px;
    }
}

/* ---------- Landing page ---------- */
.landing-hero {
    background: linear-gradient(135deg, #4f46e5 0%, #7c3aed 55%, #0ea5e9 100%);
    color: #fff;
}

.landing-section {
    scroll-margin-top: 80px;
}

.hero-mockup {
    border-radius: 18px;
    box-shadow: 0 24px 60px rgba(15, 23, 42, 0.35);
    transition: transform .4s ease;
}

    .hero-mockup:hover {
        transform: translateY(-6px) scale(1.01);
    }

/* Animação sutil de entrada dos cards */
@keyframes fadeUp {
    from {
        opacity: 0;
        transform: translateY(24px);
    }

    to {
        opacity: 1;
        transform: translateY(0);
    }
}

.fade-up {
    animation: fadeUp .6s ease both;
}

.hover-raise {
    transition: transform .25s ease, box-shadow .25s ease;
}

    .hover-raise:hover {
        transform: translateY(-6px);
        box-shadow: 0 18px 40px rgba(79, 70, 229, 0.18) !important;
    }

.plan-featured {
    border: 2px solid #4f46e5 !important;
    position: relative;
}

/* Cabeçalho da tabela de itens no layout público "Profissional" (navy). */
.lp-prof-header,
.lp-prof-header th {
    background-color: #0F172A !important;
}

    .lp-prof-header th,
    .lp-prof-header .mud-table-cell {
        color: #ffffff !important;
        font-weight: 700;
    }

/* ============================================================
   Listas mobile-first (orçamentos, clientes, produtos/serviços)
   ------------------------------------------------------------
   Em telas até a Breakpoint.Sm o MudTable empilha cada linha.
   O padrão fica alto e contraintuitivo: 6 linhas "rótulo .....
   valor" por item. Aqui transformamos esse empilhamento em
   cards compactos. O bloco precisa ficar dentro do mesmo
   @media(max-width:960px) que o MudBlazor usa para o .mud-sm-
   table, pois essa classe está sempre presente no elemento.
   ============================================================ */
@media (max-width: 960px) {
    /* Cada linha da tabela vira um card. */
    .or-list.mud-sm-table .mud-table-body {
        border-top: none;
    }

    .or-list.mud-sm-table .mud-table-row {
        display: flex;
        flex-direction: column;
        margin: 12px 0;
        border: 1px solid var(--mud-palette-table-lines);
        border-radius: 14px;
        background: var(--mud-palette-surface);
        box-shadow: 0 1px 3px rgba(15, 23, 42, .06);
        overflow: hidden;
    }

        .or-list.mud-sm-table .mud-table-row:first-of-type {
            margin-top: 4px;
        }

    /* Campos bem mais compactos (o padrão era 14px por célula). */
    .or-list.mud-sm-table .mud-table-cell {
        padding: 8px 14px;
        min-height: 0;
        font-size: .9rem;
    }

        /* Divisória sutil entre campos; remove a borda inferior padrão. */
        .or-list.mud-sm-table .mud-table-cell:not(:last-child) {
            border-bottom: 1px solid var(--mud-palette-lines-default);
        }

    .or-list.mud-sm-table .mud-table-row .mud-table-cell:last-child {
        border-bottom: none;
    }

    /* Rótulo do campo (data-label) discreto, sem encolher. */
    .or-list.mud-sm-table .mud-table-cell::before {
        color: var(--mud-palette-text-secondary);
        font-weight: 500;
        font-size: .8rem;
        flex-shrink: 0;
    }

    /* Striping vira ruído no formato card. */
    .or-list.mud-sm-table .mud-table-row:nth-of-type(even) .mud-table-cell {
        background: transparent;
    }

    /* Célula principal (nome/cliente): título do card, sem rótulo, no topo. */
    .or-list.mud-sm-table .or-card-primary {
        display: block;
        order: -1;
        padding-top: 12px;
        padding-bottom: 10px;
        font-weight: 700;
        font-size: 1rem;
    }

        .or-list.mud-sm-table .or-card-primary::before {
            content: none;
        }

    /* Célula de ações: rótulo oculto; vira o rodapé do card. Os botões
       dividem a linha em colunas de largura igual, cada um centralizado
       na sua coluna e com a coluna inteira clicável (alvo de toque maior). */
    .or-list.mud-sm-table .or-card-actions {
        padding: 0;
        gap: 0;
        background: var(--mud-palette-background);
    }

        .or-list.mud-sm-table .or-card-actions::before {
            content: none;
        }

        /* Cada botão estica para ocupar uma coluna igual; o clique é
           disparado em qualquer ponto da coluna, não só sobre o ícone. */
        .or-list.mud-sm-table .or-card-actions .mud-button-root {
            flex: 1 1 0;
            margin: 0;
            height: 48px;
            border-radius: 0;
            justify-content: center;
        }

        /* Divisória sutil entre as colunas. */
        .or-list.mud-sm-table .or-card-actions .mud-button-root:not(:last-child) {
            border-right: 1px solid var(--mud-palette-lines-default);
        }
}

/* Em smartphones, reduz o respiro lateral e dá ao botão de ação
   da lista a largura total para um toque mais confortável. */
@media (max-width: 600px) {
    .or-list-paper {
        padding: 12px !important;
    }

    .or-list-header {
        flex-direction: column;
        align-items: stretch !important;
    }

        .or-list-header .mud-button-root {
            width: 100%;
        }
}

/* ============================================================
   Editor de orçamento em modo somente leitura
   ------------------------------------------------------------
   Quando o orçamento já foi entregue (enviado/aceito/recusado),
   o editor aparece travado. O objetivo é ser perceptível mas
   discreto: os campos continuam legíveis, só não editáveis, e o
   botão de salvar dá lugar a um selo "Somente leitura". A trava
   real continua no backend (e num guard no Salvar do editor).
   ============================================================ */
.or-readonly-chip {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    padding: 12px;
    border: 1px dashed var(--mud-palette-lines-default);
    border-radius: 10px;
    color: var(--mud-palette-text-secondary);
    font-weight: 600;
}

/* Tom levemente "travado" nos campos: sutil, mas perceptível. */
.or-editor-ro .mud-input-slot {
    background-color: rgba(148, 163, 184, .07);
    cursor: default;
}
