/* Arte Longa · page-specific styles. */

/* HOME ----------------------------------------------------------------- */
.home-wrap {
    min-height: calc(100vh - 14vh);
    display: flex;
    flex-direction: column;
    justify-content: center;
}
.home-hero { margin-bottom: 6vh; }
.home-title {
    font-size: clamp(3rem, 7vw, 5.5rem);
    font-weight: 800;
    letter-spacing: -0.035em;
    line-height: 1;
    color: #0a0a0a;
}
.home-subtitle {
    margin-top: 1.2vh;
    font-size: clamp(0.9rem, 1.6vw, 1.1rem);
    letter-spacing: 0.22em;
    text-transform: lowercase;
    color: #999;
}
.home-menu { list-style: none; max-width: 640px; }
.home-menu a {
    display: flex;
    justify-content: space-between;
    align-items: baseline;
    padding: 2.8vh 0;
    color: #0a0a0a;
    text-decoration: none;
    font-size: clamp(1.7rem, 3.5vw, 2.6rem);
    font-weight: 800;
    letter-spacing: -0.025em;
    line-height: 1.1;
    border-bottom: 1px solid #eaeaea;
    transition: padding-left 0.25s cubic-bezier(0.22, 1, 0.36, 1), opacity 0.2s;
}
.home-menu a:hover { padding-left: 0.6rem; opacity: 0.65; }
.home-menu li:last-child a { border-bottom: none; }
.home-menu .arrow {
    font-size: 0.85rem;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    font-weight: 500;
    color: #bbb;
    transition: color 0.2s;
}
.home-menu a:hover .arrow { color: #0a0a0a; }
.home-meta {
    margin-top: 5vh;
    display: flex;
    gap: 0.8rem;
    align-items: center;
    font-size: 0.68rem;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: #999;
}
.home-meta a { color: #888; text-decoration: none; font-weight: 500; transition: color 0.2s; }
.home-meta a:hover { color: #0a0a0a; }
.home-meta .sep { color: #ddd; }

/* PARCEIROS (roster) --------------------------------------------------- */
.statement {
    font-size: clamp(2.2rem, 4.5vw, 4.2rem);
    font-weight: 800;
    letter-spacing: -0.03em;
    line-height: 1.1;
    margin-bottom: 4vh;
}
.roster { list-style: none; max-width: 760px; }
/* Linha enxuta para encurtar distância mouse → cartão flutuante.
   (Cada row continua clicável com padding em torno do nome/role.) */
.roster li { padding: 0.5vh 0; position: relative; }
.roster li::after {
    content: '';
    position: absolute;
    bottom: 0; left: 0; right: 0; height: 1px;
    background: linear-gradient(to right, #ddd 30%, transparent);
}
.roster li:last-child::after { display: none; }
.roster li.section-break { margin-top: 3vh; padding-top: 3vh; }
.roster li.section-break::before {
    content: '';
    position: absolute; top: 0; left: 0;
    width: 60px; height: 2px;
    background: #0a0a0a;
}

.row { display: flex; justify-content: space-between; align-items: baseline; }
.roster a.name {
    font-size: clamp(1.3rem, 2.5vw, 1.8rem);
    font-weight: 700;
    color: #0a0a0a;
    text-decoration: none;
    transition: opacity 0.2s;
}
.roster a.name:hover { opacity: 0.45; }

/* em-memória: honra ao legado — italic, dessaturado.
   Uso restrito a `entity.emMemoria`. Não aplicar em "em breve"
   (que sugere vinda, não despedida). */
.roster li.em-memoria a.name { color: #c5c5c5; font-style: italic; font-weight: 500; }
.roster li.em-memoria .role { color: #d5d5d5; font-style: italic; }

/* em-breve: chega em breve, energia futura. Peso normal,
   sem italic — preserva a presença da pessoa na rede. O próprio
   texto "em breve" no role basta como sinal. */
.roster li.em-breve .role {
    color: #888;
    font-weight: 500;
}

/* Marcador de sócio — asterisco discreto ao lado do nome.
   Visual minimal: cor dessaturada, peso leve, tamanho relativo menor.
   A legenda abaixo do roster explica o símbolo + insinua expansão contínua. */
.socio-mark {
    display: inline-block;
    margin-left: 0.2em;
    color: #bbb;
    font-weight: 400;
    font-size: 0.7em;
    vertical-align: super;
    user-select: none;
}
.socio-legend {
    margin-top: 3vh;
    font-size: 0.68rem;
    letter-spacing: 0.12em;
    text-transform: lowercase;
    color: #999;
    font-style: italic;
}
.socio-legend .socio-mark {
    vertical-align: baseline;
    font-size: 1em;
    margin-right: 0.2em;
    margin-left: 0;
}
.role {
    font-size: 0.65rem;
    font-weight: 500;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: #aaa;
    user-select: none;
    cursor: pointer;
    padding: 0.5em 0 0.5em 0.8em;
}
/* Cartão flutuante — não empurra a lista.
   position:absolute sobre <li> (position:relative) + opacidade + pointer-events
   para garantir hit-test limpo quando oculto. O cartão pousa abaixo da linha e
   vive por cima das linhas seguintes (z-index maior). */
.card {
    position: absolute;
    /* Encosta o cartão imediatamente abaixo do nome/role da linha.
       Cortamos o padding-bottom do li via calc para colar. */
    top: calc(100% - 0.5vh);
    left: 0;
    right: 0;
    background: #fff;
    border: 1px solid #0a0a0a;
    box-shadow: 0 14px 36px rgba(0, 0, 0, 0.12);
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.15s ease-out;
    z-index: 30;
    padding: 0 1.4rem;
}
.roster li:hover .card,
.roster li.open .card {
    opacity: 1;
    pointer-events: auto;
    transform: translateY(0);
}
.roster li.servicos-open .card {
    /* popover aberto prende o cartão visível mesmo sem hover */
    opacity: 1;
    pointer-events: auto;
    transform: translateY(0);
}
/* Padding-top enxuto: o conteúdo do cartão pousa imediatamente abaixo da row.
   1.6vh antes deixava o bio/bio-curta 26px abaixo do cursor — sensação de "longe". */
.card-inner { display: flex; gap: 2rem; padding: 0.5vh 0.2rem 0.8vh; align-items: flex-start; }
.card-left {
    flex: 1; min-width: 0;
    display: flex; flex-direction: column; gap: 1.1rem; align-items: flex-start;
}
.profile-block { display: flex; gap: 1rem; align-items: flex-start; }
.card-bio {
    font-size: 0.82rem;
    color: #777;
    line-height: 1.55;
    padding-top: 0.2rem;
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
}
.card-bio.empty { color: #c8c8c8; font-style: italic; }
.card-right { flex-shrink: 0; text-align: right; display: flex; flex-direction: column; align-items: flex-end; gap: 0.9rem; position: relative; }
.card-missoes { list-style: none; }
.card-missoes li { font-size: 0.78rem; color: #777; letter-spacing: 0.02em; padding: 0.22em 0; }
.card-missoes li::before { content: "· "; color: #bbb; }

.card-membros { list-style: none; min-width: 240px; width: 100%; }
.mini-row { display: block; padding: 0.45em 0; border-bottom: 1px solid #f0f0f0; cursor: pointer; }
.mini-row:last-child { border-bottom: none; }
.mini-name {
    font-size: 0.88rem;
    font-weight: 600;
    color: #333;
    text-decoration: none;
    transition: opacity 0.2s;
    display: inline-block;
}
.mini-name:hover { opacity: 0.5; }
.mini-drawer {
    max-height: 0; overflow: hidden; opacity: 0;
    transition: max-height 0.35s cubic-bezier(0.22, 1, 0.36, 1), opacity 0.25s;
}
/* Só abre por clique — hover causaria shift dos membros seguintes dentro do cartão. */
.mini-row.open .mini-drawer { max-height: 220px; opacity: 1; }
.mini-missoes { list-style: none; padding: 0.35em 0 0.15em 1em; }
.mini-missoes li { font-size: 0.72rem; color: #888; padding: 0.15em 0; letter-spacing: 0.02em; }
.mini-missoes li::before { content: "· "; color: #ccc; }
.mini-memoria { font-size: 0.6rem; letter-spacing: 0.14em; color: #b0b0b0; font-style: italic; margin-left: 0.6em; }
.mini-row-memoria .mini-name { font-style: italic; color: #666; }

.card-membros .mini-hidden { display: none; }
.card-membros.membros-expanded .mini-hidden { display: block; }

.membros-more-btn {
    margin-top: 0.6rem;
    font-family: inherit;
    font-size: 0.6rem;
    font-weight: 600;
    letter-spacing: 0.2em;
    text-transform: uppercase;
    color: #0a0a0a;
    background: none;
    border: none;
    padding: 0.4em 0;
    cursor: pointer;
    text-decoration: underline;
    text-underline-offset: 0.25em;
    transition: opacity 0.2s;
    align-self: flex-start;
    width: 100%;
    text-align: left;
}
.membros-more-btn:hover { opacity: 0.55; }

.see-more {
    display: inline-block;
    font-size: 0.6rem; font-weight: 600;
    letter-spacing: 0.16em; text-transform: uppercase;
    color: #0a0a0a; text-decoration: none;
    border: 1px solid #0a0a0a; padding: 0.55em 1em;
    transition: background 0.2s, color 0.2s;
}
.see-more:hover { background: #0a0a0a; color: #fff; }

.coda {
    margin-top: 5vh;
    max-width: 760px;
    display: flex;
    justify-content: flex-end;
}
.coda .when { font-size: 0.6rem; letter-spacing: 0.2em; color: #ccc; }

/* SERVICOS ------------------------------------------------------------- */
.page-title {
    font-size: clamp(2rem, 4vw, 3rem);
    font-weight: 800;
    letter-spacing: -0.03em;
    margin-bottom: 1vh;
}
.page-subtitle {
    font-size: 0.75rem;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: #999;
    margin-bottom: 5vh;
}
.controls { display: flex; gap: 0.8rem; flex-wrap: wrap; margin-bottom: 2vh; }
.controls input[type="search"] {
    font-family: inherit;
    font-size: 0.88rem;
    padding: 0.7em 1em;
    border: 1px solid #ddd;
    background: #fff;
    color: #333;
    border-radius: 2px;
    outline: none;
    transition: border-color 0.2s;
    flex: 1; min-width: 220px;
}
.controls input[type="search"]:focus { border-color: #0a0a0a; }
.count {
    font-size: 0.68rem;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    color: #aaa;
    margin-bottom: 1vh;
}
.portfolio-list { list-style: none; }
.portfolio-list li {
    padding: 2vh 0;
    border-bottom: 1px solid #eee;
    cursor: pointer;
    display: flex;
    justify-content: space-between;
    align-items: baseline;
    gap: 1rem;
    transition: padding-left 0.2s, background 0.15s;
}
.portfolio-list li:hover { padding-left: 0.5rem; background: #fafafa; }
.portfolio-list li:last-child { border-bottom: none; }
.portfolio-titulo {
    font-size: clamp(1.05rem, 2.2vw, 1.3rem);
    font-weight: 700;
    letter-spacing: -0.01em;
    color: #0a0a0a;
}
.portfolio-resp {
    font-size: 0.72rem;
    color: #888;
    letter-spacing: 0.02em;
    flex-shrink: 0;
    text-align: right;
}
.empty-state { padding: 6vh 0; text-align: center; color: #bbb; font-style: italic; }

.portfolio-list .portfolio-link {
    display: flex;
    justify-content: space-between;
    align-items: baseline;
    gap: 1rem;
    color: inherit;
    text-decoration: none;
    width: 100%;
}

/* Parent service with children — show hover-drawer */
.portfolio-list li.has-children .portfolio-expand {
    display: inline-block;
    margin-left: 0.6em;
    font-size: 0.62rem;
    letter-spacing: 0.14em;
    color: #fff;
    background: #0a0a0a;
    padding: 0.25em 0.6em;
    border-radius: 2px;
    font-weight: 600;
    vertical-align: middle;
}
.portfolio-parent {
    font-size: 0.72rem;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: #aaa;
    margin-right: 0.4em;
}
.portfolio-children {
    list-style: none;
    max-height: 0;
    overflow: hidden;
    opacity: 0;
    transition: max-height 0.4s cubic-bezier(0.22, 1, 0.36, 1), opacity 0.25s, padding 0.3s;
    padding: 0;
}
.portfolio-list li.has-children:hover .portfolio-children,
.portfolio-list li.has-children.open .portfolio-children {
    max-height: 600px;
    opacity: 1;
    padding: 0.5rem 0 0.8rem 1.5rem;
    border-left: 2px solid #eee;
    margin-left: 0.4rem;
}
.portfolio-children li {
    padding: 0.5rem 0 !important;
    border-bottom: 1px solid #f5f5f5;
}
.portfolio-children li:last-child { border-bottom: none !important; }
.portfolio-children .child-link {
    font-size: 0.88rem;
    color: #444;
    display: block;
}
.portfolio-children .child-link:hover { color: #0a0a0a; }

/* SERVICE DETAIL ------------------------------------------------------- */
.service-crumb {
    font-size: 0.65rem;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: #999;
    margin-bottom: 3vh;
}
.service-crumb a { color: inherit; text-decoration: none; }
.service-crumb a:hover { opacity: 0.5; }

.service-label {
    font-size: 0.65rem;
    font-weight: 600;
    letter-spacing: 0.24em;
    text-transform: uppercase;
    color: #aaa;
    margin-bottom: 1vh;
}
.service-title {
    font-size: clamp(2.4rem, 5.5vw, 4rem);
    font-weight: 800;
    letter-spacing: -0.03em;
    line-height: 1.05;
    color: #0a0a0a;
    margin-bottom: 2vh;
}
.service-resp {
    font-size: 0.95rem;
    color: #555;
    letter-spacing: 0.02em;
    margin-bottom: 5vh;
}
.service-resp a { color: #0a0a0a; font-weight: 600; text-decoration: none; transition: opacity 0.2s; }
.service-resp a:hover { opacity: 0.5; }

.service-cnae-list, .service-sols-list, .service-missoes-list, .service-related {
    list-style: none;
    margin-bottom: 3vh;
}
.service-cnae-list li {
    padding: 0.9rem 0;
    border-bottom: 1px solid #f4f4f4;
    display: grid;
    grid-template-columns: 110px 1fr;
    gap: 1rem;
    align-items: baseline;
}
.service-cnae-list li:last-child { border-bottom: none; }
.service-cnae-list .cnae-code {
    font-family: 'SF Mono', Monaco, 'Cascadia Code', 'Roboto Mono', Consolas, monospace;
    font-size: 0.82rem;
    color: #0a0a0a;
    font-weight: 600;
}
.service-cnae-list .cnae-desc {
    font-size: 0.9rem;
    color: #333;
    line-height: 1.5;
}

.service-sols-list li {
    padding: 1rem 0;
    border-bottom: 1px solid #eee;
}
.service-sols-list li:last-child { border-bottom: none; }
.service-sols-list a {
    color: inherit;
    text-decoration: none;
    display: flex;
    gap: 1rem;
    align-items: baseline;
    flex-wrap: wrap;
    transition: padding-left 0.2s;
}
.service-sols-list a:hover { padding-left: 0.4rem; }
.service-sols-list strong { font-size: 1.05rem; font-weight: 700; color: #0a0a0a; }
.service-sols-list .sol-tagline {
    font-size: 0.72rem;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: #888;
}

/* Em missões — mesmo visual de soluções (coerência de leitura) */
.service-missoes-list li {
    padding: 1rem 0;
    border-bottom: 1px solid #eee;
}
.service-missoes-list li:last-child { border-bottom: none; }
.service-missoes-list a {
    color: inherit;
    text-decoration: none;
    display: flex;
    gap: 1rem;
    align-items: baseline;
    flex-wrap: wrap;
    transition: padding-left 0.2s;
}
.service-missoes-list a:hover { padding-left: 0.4rem; }
.service-missoes-list strong { font-size: 1.05rem; font-weight: 700; color: #0a0a0a; }
.service-missoes-list .sol-tagline {
    font-size: 0.72rem;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: #888;
}

.service-related li {
    padding: 0.4rem 0;
    font-size: 0.9rem;
}
.service-related li::before { content: "· "; color: #bbb; }
.service-related a { color: #333; text-decoration: none; transition: opacity 0.2s; }
.service-related a:hover { opacity: 0.55; text-decoration: underline; }

.service-contact {
    padding: 3vh 0;
    text-align: center;
}
.service-contact .modal-email {
    font-size: clamp(1.3rem, 3vw, 1.8rem);
    font-weight: 800;
    letter-spacing: -0.01em;
    color: #0a0a0a;
    user-select: all;
    word-break: break-all;
}

.empty-line {
    color: #aaa;
    font-style: italic;
    font-size: 0.9rem;
    padding: 1vh 0 3vh;
}

.intro-short {
    color: #555;
    font-size: 0.9rem;
    margin-bottom: 2.5vh;
    max-width: 60ch;
}

.service-summary {
    font-size: 1.02rem;
    color: #333;
    line-height: 1.7;
    max-width: 62ch;
    margin-bottom: 4vh;
    padding: 2.5vh 0;
    border-top: 1px solid #eee;
    border-bottom: 1px solid #eee;
}
.service-attachments { list-style: none; margin-bottom: 3vh; }
.service-attachments .attachment-link {
    display: grid;
    grid-template-columns: 80px 1fr auto;
    align-items: center;
    gap: 1rem;
    padding: 1.8vh 0;
    border-bottom: 1px solid #eee;
    color: inherit;
    text-decoration: none;
    transition: padding-left 0.2s, background 0.15s;
}
.service-attachments .attachment-link:hover { padding-left: 0.5rem; background: #fafafa; }
.service-attachments li:last-child .attachment-link { border-bottom: none; }
.att-kind {
    font-family: 'SF Mono', Monaco, 'Cascadia Code', 'Roboto Mono', Consolas, monospace;
    font-size: 0.65rem;
    letter-spacing: 0.12em;
    color: #fff;
    background: #0a0a0a;
    padding: 0.35em 0.6em;
    text-align: center;
    font-weight: 600;
}
.att-label { font-size: 0.95rem; color: #0a0a0a; font-weight: 600; }
.att-arrow {
    font-size: 0.62rem;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: #888;
    font-weight: 500;
}

/* ENSAIOS / PUBLICAÇÕES ------------------------------------------------ */
/* Lista numerada com dois formatos (curto + longo) por item. Placeholders
   "em breve" renderizam cinza-claro e sem link até a URL chegar. */
.essays-list { list-style: none; }
.essays-list li {
    display: grid;
    grid-template-columns: auto 1fr auto;
    gap: 1rem;
    padding: 0.7rem 0;
    font-size: 0.92rem;
    color: #333;
    border-bottom: 1px solid #f4f4f4;
    align-items: baseline;
}
.essays-list li:last-child { border-bottom: none; }
.essay-num {
    font-size: 0.68rem;
    font-weight: 700;
    letter-spacing: 0.18em;
    color: #aaa;
    font-variant-numeric: tabular-nums;
}
.essay-titulo { color: #0a0a0a; }
.essay-formats {
    font-size: 0.76rem;
    color: #888;
    letter-spacing: 0.04em;
    font-variant-numeric: tabular-nums;
}
.essay-formats a {
    color: #0a0a0a;
    text-decoration: none;
    border-bottom: 1px dotted #bbb;
    padding-bottom: 1px;
}
.essay-formats a:hover { color: #555; border-bottom-color: #555; }
.essay-pending {
    color: #c8c8c8;
    font-style: italic;
}

@media (max-width: 640px) {
    .essays-list li {
        grid-template-columns: auto 1fr;
        grid-template-areas: "num titulo" "num formats";
        row-gap: 0.2rem;
    }
    .essay-num { grid-area: num; }
    .essay-titulo { grid-area: titulo; }
    .essay-formats { grid-area: formats; }
}

/* POEMAS (lista no perfil) -------------------------------------------- */
.poemas-list { list-style: none; }
.poemas-list li {
    padding: 0.55rem 0;
    border-bottom: 1px solid #f4f4f4;
    font-size: 0.95rem;
}
.poemas-list li:last-child { border-bottom: none; }
.poemas-list a {
    color: #0a0a0a;
    text-decoration: none;
    border-bottom: 1px dotted #bbb;
    padding-bottom: 1px;
}
.poemas-list a:hover { color: #555; border-bottom-color: #555; }

/* POEMA (página) ------------------------------------------------------ */
.poem-page { max-width: 640px; }
.poem-title {
    font-size: 1.8rem;
    letter-spacing: 0.04em;
    text-align: center;
    margin: 2vh 0 0.5rem;
}
.poem-author {
    text-align: center;
    font-size: 0.85rem;
    color: #888;
    margin-bottom: 3vh;
    letter-spacing: 0.06em;
}
.poem-author a { color: #555; text-decoration: none; border-bottom: 1px dotted #bbb; }
.poem-author a:hover { color: #0a0a0a; }
.poem-body {
    font-size: 1rem;
    line-height: 1.7;
    color: #1a1a1a;
}
.poem-stanza {
    margin: 0 0 1.6rem;
    white-space: normal;
}
.poem-stanza:last-child { margin-bottom: 2rem; }

/* RECURSOS ------------------------------------------------------------- */
.fin-list { list-style: none; margin-bottom: 3vh; }
.fin-item {
    padding: 2.2vh 0;
    border-bottom: 1px solid #eee;
}
.fin-item:last-child { border-bottom: none; }
.fin-head {
    display: flex;
    justify-content: space-between;
    align-items: baseline;
    gap: 1rem;
}
.fin-label {
    font-size: 1.02rem;
    font-weight: 700;
    color: #0a0a0a;
    letter-spacing: -0.01em;
}
.fin-value {
    font-size: 1.1rem;
    font-weight: 800;
    letter-spacing: -0.01em;
    color: #0a0a0a;
    font-variant-numeric: tabular-nums;
}
.fin-detail {
    font-size: 0.78rem;
    color: #888;
    margin-top: 0.4rem;
    letter-spacing: 0.02em;
    line-height: 1.5;
}
.fin-solucoes {
    margin-top: 0.5rem;
    font-size: 0.72rem;
    letter-spacing: 0.06em;
    color: #999;
    text-transform: uppercase;
}
.fin-sol-link {
    color: #0a0a0a;
    text-decoration: none;
    font-weight: 700;
    letter-spacing: 0.02em;
    text-transform: none;
    border-bottom: 1px dotted #bbb;
    padding-bottom: 1px;
    transition: border-color 0.15s, color 0.15s;
}
.fin-sol-link:hover { color: #555; border-bottom-color: #555; }
.fin-sub-breakdown {
    margin-top: 0.6rem;
    padding-left: 1rem;
    border-left: 2px solid #eee;
}
.fin-sub-breakdown .sub-line {
    display: flex;
    justify-content: space-between;
    font-size: 0.82rem;
    color: #666;
    padding: 0.25em 0;
    font-variant-numeric: tabular-nums;
}

.fin-total {
    display: flex;
    justify-content: space-between;
    align-items: baseline;
    padding: 3vh 0 1.5vh;
    border-top: 2px solid #0a0a0a;
}
.fin-total-secondary {
    display: flex;
    justify-content: space-between;
    align-items: baseline;
    padding: 0 0 2vh;
    margin-bottom: 4vh;
    border-bottom: 2px solid #0a0a0a;
    font-size: 0.8rem;
    color: #666;
    letter-spacing: 0.04em;
    font-variant-numeric: tabular-nums;
}
.fin-total-secondary span:first-child {
    text-transform: uppercase;
    letter-spacing: 0.18em;
    font-weight: 500;
    color: #888;
    font-size: 0.68rem;
}
.fin-total-secondary span:last-child {
    font-weight: 700;
    color: #0a0a0a;
}
.fin-total-label {
    font-size: 0.7rem;
    font-weight: 700;
    letter-spacing: 0.22em;
    text-transform: uppercase;
    color: #0a0a0a;
}
.fin-total-value {
    font-size: clamp(1.6rem, 3.2vw, 2rem);
    font-weight: 800;
    letter-spacing: -0.02em;
    color: #0a0a0a;
    font-variant-numeric: tabular-nums;
}

.fin-goal-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 2rem;
    margin-bottom: 4vh;
}
.fin-goal-grid-3 {
    grid-template-columns: repeat(3, 1fr);
    gap: 1.25rem;
}
.fin-goal {
    padding: 3vh 1.4rem;
    border: 1px solid #eee;
}
.fin-goal-label {
    font-size: 0.65rem;
    font-weight: 600;
    letter-spacing: 0.2em;
    text-transform: uppercase;
    color: #999;
    margin-bottom: 0.8rem;
}
.fin-goal-value {
    font-size: clamp(1.8rem, 4vw, 2.4rem);
    font-weight: 800;
    letter-spacing: -0.02em;
    color: #0a0a0a;
    font-variant-numeric: tabular-nums;
    margin-bottom: 0.4rem;
}
.fin-goal-note {
    font-size: 0.72rem;
    color: #888;
    letter-spacing: 0.02em;
}

.fin-footnote {
    font-size: 0.8rem;
    color: #888;
    margin-top: 3vh;
    line-height: 1.6;
}
.fin-footnote a { color: #0a0a0a; font-weight: 600; text-decoration: none; }
.fin-footnote a:hover { opacity: 0.5; }

/* Closing "Próximos Passos" link, used at the bottom of /recursos/ etc. */
.proximos-link-bottom {
    margin-top: 4vh;
    font-size: 0.95rem;
    font-weight: 600;
}
.proximos-link-bottom a {
    color: #0a0a0a;
    text-decoration: none;
    border-bottom: 1px solid #0a0a0a;
    padding-bottom: 2px;
    transition: color 0.15s ease, border-color 0.15s ease;
}
.proximos-link-bottom a:hover { color: #c0392b; border-bottom-color: #c0392b; }

/* Strong inside .intro — slightly heavier numerals */
.intro strong { color: #0a0a0a; font-weight: 700; }

.fin-unit {
    font-size: 0.65em;
    font-weight: 500;
    color: #999;
    letter-spacing: 0.04em;
    margin-left: 0.2em;
}
.client-tag {
    display: inline-block;
    font-size: 0.58rem;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: #888;
    background: #f4f4f4;
    padding: 0.25em 0.55em;
    margin-left: 0.6em;
    vertical-align: middle;
    font-weight: 500;
}
.sub-link {
    font-size: 0.85em;
    color: #bbb;
    text-decoration: none;
    margin-left: 0.3em;
}
.sub-link:hover { color: #0a0a0a; }

.fin-item.pro-bono .fin-value.pro-bono-tag {
    font-size: 0.62rem;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: #fff;
    background: #0a0a0a;
    padding: 0.4em 0.9em;
    font-weight: 700;
}

.fin-subtotal {
    display: flex;
    justify-content: space-between;
    align-items: baseline;
    padding: 1.2vh 0;
    font-size: 0.82rem;
    color: #666;
    border-bottom: 1px solid #f4f4f4;
    font-variant-numeric: tabular-nums;
    letter-spacing: 0.02em;
}
.fin-subtotal:last-of-type { border-bottom: none; margin-bottom: 2vh; font-weight: 600; color: #0a0a0a; }

.fin-goal.highlighted {
    border: 2px solid #0a0a0a;
    background: #fafafa;
}

.fin-breakdown-summary {
    margin: 2vh 0 4vh;
    padding: 2vh 0;
    border-top: 1px solid #eee;
    border-bottom: 2px solid #0a0a0a;
}
.fin-breakdown-summary .sum-line {
    display: flex;
    justify-content: space-between;
    padding: 0.6vh 0;
    font-size: 0.88rem;
    color: #555;
    font-variant-numeric: tabular-nums;
}
.fin-breakdown-summary .sum-total {
    font-weight: 800;
    font-size: 1.05rem;
    color: #0a0a0a;
    border-top: 1px solid #eee;
    margin-top: 0.8vh;
    padding-top: 1.2vh;
}

@media (max-width: 640px) {
    .fin-goal-grid,
    .fin-goal-grid-3 { grid-template-columns: 1fr; }
}

/* SOLUCOES ------------------------------------------------------------- */
.intro {
    font-size: 0.95rem;
    color: #444;
    line-height: 1.7;
    margin-bottom: 5vh;
    max-width: 60ch;
}
.solucoes-list { list-style: none; padding: 0; }
.solucao { padding: 4vh 0; border-bottom: 1px solid #eee; }
.solucao:last-child { border-bottom: none; }

/* Universos · catálogo enxuto em /solucoes/ */
.universos-catalog {
    list-style: none;
    margin: 0 0 5vh;
    padding: 0;
}
.universo-row {
    border-bottom: 1px solid #eee;
}
.universo-row:last-child { border-bottom: none; }
.universo-link {
    display: grid;
    grid-template-columns: 1fr auto;
    grid-template-areas:
        "nome arrow"
        "obj  arrow"
        "meta arrow";
    column-gap: 1.5rem;
    row-gap: 0.2rem;
    padding: 1.4rem 0;
    text-decoration: none;
    color: #0a0a0a;
    align-items: center;
    transition: opacity 0.15s ease;
}
.universo-link:hover { opacity: 0.55; }
.universo-nome {
    grid-area: nome;
    font-size: 1.25rem;
    font-weight: 700;
    letter-spacing: -0.01em;
}
.universo-objetivo {
    grid-area: obj;
    font-size: 0.78rem;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: #888;
}
.universo-meta {
    grid-area: meta;
    font-size: 0.72rem;
    color: #bbb;
    letter-spacing: 0.02em;
}
.universo-arrow {
    grid-area: arrow;
    font-size: 0.85rem;
    color: #bbb;
    align-self: center;
}

/* Hub navigation block (Arte Longa profile, etc.) — uma linha por item */
.home-links-list {
    list-style: none;
    margin: 0;
    padding: 0;
}
.home-links-list li {
    padding: 0.9rem 0;
    border-bottom: 1px solid #eee;
}
.home-links-list li:last-child { border-bottom: none; }
.home-links-list a {
    color: #222;
    text-decoration: none;
    font-size: 1.05rem;
    display: inline-flex;
    align-items: baseline;
    gap: 0.5rem;
    transition: color 0.15s ease;
}
.home-links-list a:hover { color: #c0392b; }
.home-links-list a::after {
    content: "→";
    font-size: 0.8rem;
    color: #bbb;
}

/* Universos diagram */
.universos-diagram-section {
    margin: 8vh 0 6vh;
    padding-top: 4vh;
    border-top: 1px solid #eee;
}
.universos-diagram-intro {
    margin-bottom: 3vh;
    font-size: 0.95rem;
}
.universos-diagram {
    display: block;
    width: 100%;
    max-width: 720px;
    height: auto;
    margin: 0 auto;
}
/* Mesh pulse — dashes flowing along the lines, evocando conexão em tempo real */
.universos-diagram .ud-pulse {
    stroke-dasharray: 4 4;
    animation: ud-pulse-flow 2.6s linear infinite;
}
@keyframes ud-pulse-flow {
    from { stroke-dashoffset: 0; }
    to   { stroke-dashoffset: -16; }
}
@media (prefers-reduced-motion: reduce) {
    .universos-diagram .ud-pulse { animation: none; }
}
.solucao-head {
    display: flex;
    justify-content: space-between;
    align-items: baseline;
    gap: 1.5rem;
    flex-wrap: wrap;
    margin-bottom: 1rem;
}
.solucao-nome {
    font-size: clamp(1.5rem, 3.2vw, 2rem);
    font-weight: 800;
    letter-spacing: -0.02em;
    color: #0a0a0a;
    text-decoration: none;
    display: inline-flex;
    align-items: baseline;
    gap: 0.7em;
    transition: opacity 0.2s;
}
.solucao-nome:hover { opacity: 0.5; }
.solucao-nome .arrow {
    font-size: 0.6rem;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    font-weight: 500;
    color: #bbb;
}
.solucao-tagline {
    font-size: 0.78rem;
    color: #888;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    font-weight: 500;
}
.solucao-url {
    display: block;
    font-size: 0.72rem;
    color: #aaa;
    letter-spacing: 0.02em;
    margin-bottom: 1rem;
}
.solucao-desc {
    font-size: 0.92rem;
    color: #444;
    line-height: 1.6;
    margin-bottom: 1.6rem;
    max-width: 70ch;
}
.solucao-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 2rem; margin-top: 1.5rem; }
.bundle-label {
    font-size: 0.62rem;
    font-weight: 700;
    letter-spacing: 0.22em;
    text-transform: uppercase;
    color: #999;
    margin-bottom: 0.8rem;
}
.bundle-list { list-style: none; }
.bundle-list li { font-size: 0.85rem; padding: 0.3em 0; letter-spacing: 0.01em; }
.bundle-list li::before { content: "· "; color: #bbb; }
.bundle-list a { color: #333; text-decoration: none; transition: opacity 0.2s; }
.bundle-list a:hover { opacity: 0.55; text-decoration: underline; }
.bundle-list .more-item { display: none; }
.bundle-list.expanded .more-item { display: block; }
.bundle-more-btn {
    margin-top: 0.6rem;
    font-family: inherit;
    font-size: 0.6rem;
    font-weight: 600;
    letter-spacing: 0.2em;
    text-transform: uppercase;
    color: #0a0a0a;
    background: none;
    border: none;
    padding: 0.4em 0;
    cursor: pointer;
    text-decoration: underline;
    text-underline-offset: 0.25em;
    transition: opacity 0.2s;
}
.bundle-more-btn:hover { opacity: 0.55; }

/* MISSÕES (em /solucoes/) ---------------------------------------------- */
.missoes-group { list-style: none; margin-bottom: 4vh; }
.missoes-comunidade-head {
    margin: 5vh 0 1.5vh;
    padding-bottom: 1vh;
    border-bottom: 1px solid #eee;
    display: flex;
    align-items: baseline;
    gap: 1rem;
}
.missoes-comunidade-head .c-label {
    font-size: 0.6rem;
    letter-spacing: 0.22em;
    text-transform: uppercase;
    color: #999;
    font-weight: 600;
}
.missoes-comunidade-head .c-link {
    font-size: 1.1rem;
    font-weight: 800;
    color: #0a0a0a;
    text-decoration: none;
    letter-spacing: -0.01em;
}
.missoes-comunidade-head .c-link:hover { opacity: 0.55; }

.missao-card {
    padding: 2.2vh 0;
    border-bottom: 1px solid #eee;
}
.missao-card:last-child { border-bottom: none; }
.missao-card.depth-1 {
    padding-left: 1.5rem;
    border-left: 2px solid #eee;
    margin-left: 1rem;
    border-bottom: none;
    margin-bottom: 0.5vh;
}
.missao-head {
    display: flex;
    justify-content: space-between;
    align-items: baseline;
    gap: 1rem;
    flex-wrap: wrap;
    margin-bottom: 0.4rem;
}
.missao-nome {
    font-size: clamp(1.1rem, 2.3vw, 1.4rem);
    font-weight: 800;
    letter-spacing: -0.01em;
    color: #0a0a0a;
}
.missao-card.depth-1 .missao-nome {
    font-size: 1rem;
}
.missao-subtitle {
    font-size: 0.78rem;
    color: #888;
    letter-spacing: 0.02em;
    font-style: italic;
}
.missao-objetivo {
    font-size: 0.9rem;
    color: #444;
    line-height: 1.55;
    margin: 0.4rem 0;
    max-width: 65ch;
}
.missao-envolvidos {
    font-size: 0.78rem;
    color: #888;
    margin-top: 0.4rem;
    letter-spacing: 0.02em;
}
.missao-envolvidos a {
    color: #0a0a0a;
    font-weight: 600;
    text-decoration: none;
}
.missao-envolvidos a:hover { opacity: 0.5; }

/* Serviços que realizam a missão — pílulas compactas dentro do card */
.missao-servicos {
    margin-top: 0.8rem;
    display: flex;
    align-items: baseline;
    gap: 0.6rem;
    flex-wrap: wrap;
}
.missao-servicos-label {
    font-size: 0.6rem;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: #999;
    font-weight: 600;
    flex-shrink: 0;
}
.missao-servicos-list {
    list-style: none;
    display: flex;
    flex-wrap: wrap;
    gap: 0.4rem 0.6rem;
    padding: 0;
    margin: 0;
}
.missao-servicos-list li {
    font-size: 0.76rem;
}
.missao-servicos-list li:not(:last-child)::after {
    content: " ·";
    color: #ccc;
    margin-left: 0.3em;
}
.missao-servicos-list a {
    color: #0a0a0a;
    text-decoration: none;
    border-bottom: 1px dotted #bbb;
    padding-bottom: 1px;
    transition: border-color 0.2s, color 0.2s;
}
.missao-servicos-list a:hover { color: #555; border-bottom-color: #555; }

.missao-attach {
    list-style: none;
    margin-top: 0.8rem;
}
.missao-attach li { padding: 0.3rem 0; }
.missao-attach a {
    font-size: 0.78rem;
    color: #0a0a0a;
    text-decoration: none;
    font-weight: 600;
    display: inline-flex;
    align-items: center;
    gap: 0.6em;
}
.missao-attach a:hover { opacity: 0.6; }
.missao-attach .att-kind {
    font-family: 'SF Mono', Monaco, 'Cascadia Code', 'Roboto Mono', Consolas, monospace;
    font-size: 0.6rem;
    letter-spacing: 0.1em;
    color: #fff;
    background: #0a0a0a;
    padding: 0.25em 0.5em;
    font-weight: 600;
}

.missao-children {
    list-style: none;
    margin-top: 1vh;
    padding-top: 1vh;
    border-top: 1px dashed #eee;
}
.missao-autor {
    font-size: 0.8rem;
    color: #888;
    font-style: italic;
    letter-spacing: 0.02em;
}
.missao-autor a { color: #0a0a0a; font-weight: 600; text-decoration: none; }
.missao-autor a:hover { opacity: 0.5; }

/* PARCERIAS no profile de comunidade */
.parceria-section { }
.parceria-desc {
    color: #444;
    font-size: 0.95rem;
    line-height: 1.6;
    max-width: 62ch;
    margin-bottom: 2vh;
}
.parceria-contribs {
    list-style: none;
}
.parceria-contribs li {
    padding: 0.7rem 0;
    border-bottom: 1px solid #f4f4f4;
    font-size: 0.9rem;
    color: #444;
    line-height: 1.55;
}
.parceria-contribs li:last-child { border-bottom: none; }
.parceria-contribs a { color: #0a0a0a; text-decoration: none; }
.parceria-contribs a:hover { opacity: 0.55; }

/* PERGUNTA/RESPOSTA em Soluções (Arte Longa framing) */
.solucao-pergunta {
    margin: 1vh 0 2vh;
    padding: 2vh 0;
    border-top: 1px solid #eee;
    border-bottom: 1px solid #eee;
    font-size: 1.1rem;
    line-height: 1.6;
}
.solucao-pergunta .q { color: #666; }
.solucao-pergunta .a {
    color: #0a0a0a;
    font-weight: 800;
    letter-spacing: -0.01em;
    margin-left: 0.4em;
}
.solucao-platforms { margin-top: 1.5rem; }

/* Lema — linha de posicionamento curta entre pergunta e desc. */
.solucao-lema {
    font-size: 1.05rem;
    font-weight: 700;
    color: #0a0a0a;
    letter-spacing: -0.01em;
    margin: 1.4vh 0 0.6vh;
}

/* Badge "+N membros" na lista de comunidade em /parceiros/ */
.card-membros .membros-badge {
    padding: 0.45em 0 !important;
    font-size: 0.72rem;
    color: #888;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    font-style: italic;
    border-bottom: none !important;
    border-top: 1px dashed #ddd;
    margin-top: 0.3em;
    padding-top: 0.8em !important;
    cursor: default;
}

/* Service children popover — floating, smaller, doesn't overflow */
.portfolio-list li.has-children .portfolio-children {
    position: absolute;
    right: 0;
    top: 100%;
    width: min(320px, 80vw);
    background: #fff;
    border: 1px solid #0a0a0a;
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.08);
    z-index: 20;
    padding: 0;
    margin-left: 0;
    max-height: 0;
    overflow: hidden;
    opacity: 0;
    transition: max-height 0.25s cubic-bezier(0.22, 1, 0.36, 1), opacity 0.2s;
    border-left: none;
}
.portfolio-list li.has-children { position: relative; }
.portfolio-list li.has-children:hover .portfolio-children,
.portfolio-list li.has-children.open .portfolio-children {
    max-height: 520px;
    opacity: 1;
    padding: 0.8rem 1.2rem;
}
.portfolio-children li {
    padding: 0.4rem 0 !important;
    font-size: 0.8rem;
    border-bottom: 1px solid #f5f5f5 !important;
}
.portfolio-children .child-link {
    font-size: 0.82rem;
    color: #0a0a0a;
    font-weight: 500;
    display: block;
}
.portfolio-children .child-link:hover { opacity: 0.55; }

/* /parceiros/ — botão "Ver serviços" + popover flutuante.
   Popover vive fora do .card (irmão) para escapar do overflow/clip e
   ancorar no <li> (position: relative). Não empurra layout. */
.ver-servicos-btn {
    font-family: inherit;
    font-size: 0.68rem;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: #555;
    background: transparent;
    border: 1px solid #ddd;
    padding: 0.6em 0.9em;
    cursor: pointer;
    transition: color 0.15s, border-color 0.15s;
}
.ver-servicos-btn:hover,
.ver-servicos-btn[aria-expanded="true"] {
    color: #0a0a0a;
    border-color: #0a0a0a;
}
.card-missoes-hint {
    font-size: 0.72rem;
    color: #c5c5c5;
    font-style: italic;
    letter-spacing: 0.08em;
}

.servicos-popover {
    position: absolute;
    right: 0;
    top: 100%;
    width: min(320px, 80vw);
    background: #fff;
    border: 1px solid #0a0a0a;
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.1);
    z-index: 50;
    padding: 1rem 1.2rem;
    display: none;
}
.servicos-open .servicos-popover { display: block; }

/* Host de popover em /solucoes/ */
.solucao { position: relative; }
.solucao-actions { position: relative; margin-top: 1.2rem; display: flex; justify-content: flex-start; }
.servicos-popover-head {
    font-size: 0.62rem;
    letter-spacing: 0.2em;
    text-transform: uppercase;
    color: #888;
    margin-bottom: 0.6rem;
    font-weight: 600;
}
.servicos-popover-list { list-style: none; max-height: 60vh; overflow-y: auto; }
.servicos-popover-list li {
    padding: 0.35em 0;
    border-bottom: 1px solid #f3f3f3;
}
.servicos-popover-list li:last-child { border-bottom: none; }
.servicos-popover-list a {
    font-size: 0.82rem;
    color: #0a0a0a;
    text-decoration: none;
    display: block;
    transition: opacity 0.15s;
}
.servicos-popover-list a:hover { opacity: 0.55; }
/* Parent (grupo) vs child (sub-serviço) — cabeçalho negrito, filhos indentados */
.servicos-popover-list li.svc-group {
    padding-top: 0.6em;
    border-bottom: none;
}
.servicos-popover-list li.svc-group:first-child { padding-top: 0; }
.servicos-popover-list li.svc-group a {
    font-weight: 700;
    font-size: 0.72rem;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: #0a0a0a;
}
.servicos-popover-list li.svc-child {
    padding-left: 0.9rem;
    border-bottom: 1px solid #f7f7f7;
}
.servicos-popover-list li.svc-child a {
    font-size: 0.78rem;
    color: #555;
}
.servicos-popover-list li.svc-child a:hover { color: #0a0a0a; opacity: 1; }

@media (max-width: 640px) {
    .servicos-popover { right: 0; left: 0; width: auto; }

    .home-menu a { padding: 2.4vh 0; }
    .home-menu .arrow { font-size: 0.72rem; }
    .portfolio-list li { flex-direction: column; gap: 0.4rem; align-items: flex-start; }
    .portfolio-resp { text-align: left; }
    .solucao-head { flex-direction: column; align-items: flex-start; gap: 0.4rem; }
    .solucao-grid { grid-template-columns: 1fr; gap: 1.5rem; }
    .platforms { flex-direction: column; gap: 0.6rem; }
    .lead-magnet { padding: 4vh 2rem; }
    .card-inner { flex-direction: column; gap: 1.2rem; }
    .card-right { text-align: left; align-items: flex-start; }
}
