/**
 * com_anuariocoop :: view pública "Dados do Cooperativismo"
 * Escopo isolado em .ac-dados-view — não afeta o template global (Helix).
 *
 * @copyright (C) 2026 OCB / SESCOOP
 * @license   GNU General Public License version 3 or later; see LICENSE.txt
 */

.ac-dados-view {
    --ac-dados-max-width: 1320px;
    --ac-dados-gap: 24px;
    --ac-dados-radius: 18px;
    --ac-dados-surface: #ffffff;
    --ac-dados-bg: #f6f7fb;
    --ac-dados-border: #e6e8f0;
    --ac-dados-navy: #171c66;
    --ac-dados-blue: #5883d0;
    --ac-dados-green: #6fbc85;
    --ac-dados-ink: #1f2433;
    --ac-dados-ink-2: #444b60;
    --ac-dados-muted: #8a90a6;

    /*
     * Altura do menu principal do template Sistema OCB/Helix.
     * Ajuste fino se necessário: 68px, 70px, 72px...
     */
    --ac-template-header-height: 70px;

    /*
     * Altura aproximada da barra do AnuárioCoop.
     */
    --ac-dados-submenu-height: 84px;

    color: var(--ac-dados-ink);
    font-family: inherit;
    line-height: 1.5;

    width: 100vw;
    max-width: 100vw;
    margin-left: calc(50% - 50vw);
    margin-right: calc(50% - 50vw);

    overflow-x: visible;
    overflow-y: visible;

    background: var(--ac-dados-bg);
}

.ac-dados-view *,
.ac-dados-view *::before,
.ac-dados-view *::after {
    box-sizing: border-box;
}

.ac-dados-container {
    width: min(100% - 48px, var(--ac-dados-max-width));
    margin-inline: auto;
}

/*
 * Corrige o empilhamento do Helix.
 * O menu principal e seus dropdowns precisam ficar acima da barra do Anuário.
 */
body:has(.ac-dados-view) #sp-header,
body:has(.ac-dados-view) header#sp-header,
body:has(.ac-dados-view) .sp-header,
body:has(.ac-dados-view) .header,
body:has(.ac-dados-view) .header-sticky,
body:has(.ac-dados-view) .sticky-header {
    z-index: 5000 !important;
}

body:has(.ac-dados-view) .sp-megamenu-wrapper,
body:has(.ac-dados-view) .sp-megamenu-parent,
body:has(.ac-dados-view) .sp-menu,
body:has(.ac-dados-view) .menu-parent {
    position: relative;
    z-index: 5100 !important;
}

body:has(.ac-dados-view) .sp-dropdown,
body:has(.ac-dados-view) .sp-dropdown-main,
body:has(.ac-dados-view) .sp-megamenu-parent .sp-dropdown,
body:has(.ac-dados-view) .sp-megamenu-parent .sp-dropdown-inner,
body:has(.ac-dados-view) .offcanvas-overlay {
    z-index: 5200 !important;
}

/*
 * Remove o espaço que o Helix coloca antes do componente.
 */
body:has(.ac-dados-view) #sp-main-body,
body:has(.ac-dados-view) #sp-component,
body:has(.ac-dados-view) .body-wrapper,
body:has(.ac-dados-view) .site-wrapper,
body:has(.ac-dados-view) .site-grid,
body:has(.ac-dados-view) main,
body:has(.ac-dados-view) .container-component,
body:has(.ac-dados-view) .com-content,
body:has(.ac-dados-view) .com-content-article {
    overflow: visible !important;
}

body:has(.ac-dados-view) #sp-main-body {
    padding-top: 0 !important;
    margin-top: 0 !important;
}

body:has(.ac-dados-view) #sp-component {
    padding-top: 0 !important;
    margin-top: 0 !important;
}

body:has(.ac-dados-view) .ac-dados-view {
    margin-top: 0 !important;
}

/* ---------------------------------------------------------------- Header */
.ac-dados-header {
    background: var(--ac-dados-surface);
    border-bottom: 1px solid var(--ac-dados-border);
}

.ac-dados-header__bar {
    background: var(--ac-dados-navy);
    color: rgba(255, 255, 255, .9);
    height: 28px;
    display: flex;
    align-items: center;
    overflow: hidden;
}

.ac-dados-header__ticker {
    display: flex;
    gap: 40px;
    white-space: nowrap;
    font-size: 11px;
    letter-spacing: .06em;
    padding-left: 32px;
}

.ac-dados-header__inner {
    display: grid;
    grid-template-columns: auto 1fr auto;
    align-items: center;
    gap: 32px;
    padding-block: 16px;
}

.ac-dados-header__brand img {
    height: 38px;
    display: block;
}

.ac-dados-header__nav {
    display: flex;
    gap: 28px;
    justify-content: center;
    flex-wrap: wrap;
}

.ac-dados-header__nav a {
    font-weight: 500;
    font-size: 14px;
    color: var(--ac-dados-ink-2);
    text-decoration: none;
}

.ac-dados-header__nav a:hover {
    color: var(--ac-dados-navy);
}

.ac-dados-header__actions {
    display: flex;
    align-items: center;
    gap: 14px;
}

.ac-dados-header__somos {
    width: 48px;
    height: 48px;
    border-radius: 50%;
    background: var(--ac-dados-green);
    color: #fff;
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
    font-weight: 700;
    font-size: 11px;
    line-height: 1.05;
}

.ac-dados-iconbtn {
    width: 38px;
    height: 38px;
    border-radius: 50%;
    border: 1.5px solid var(--ac-dados-navy);
    background: #fff;
    color: var(--ac-dados-navy);
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
}

/* ------------------------------------------------------------------ Hero */
.ac-dados-hero {
    background: linear-gradient(118deg, #171c66 0%, #2b56a8 42%, #5883d0 68%, #6fbc85 100%);
    color: #fff;
    padding-block: 30px 32px;
}

.ac-dados-hero__title {
    font-weight: 300;
    font-size: clamp(30px, 5vw, 44px);
    line-height: 1.06;
    letter-spacing: -.01em;
    color: #fff;
    margin: 0 0 12px;
}

.ac-dados-hero__meta {
    display: flex;
    align-items: center;
    gap: 10px;
    font-size: 14.5px;
    color: rgba(255, 255, 255, .85);
    margin: 0;
    flex-wrap: wrap;
}

.ac-dados-hero__loc {
    display: inline-flex;
    align-items: center;
    gap: 6px;
}

.ac-dados-hero__sep {
    opacity: .5;
}

/* --------------------------------------------------------------- Submenu */
.ac-dados-submenu {
    position: sticky !important;
    top: var(--ac-template-header-height);
    z-index: 300;
    width: 100%;
    background: rgba(255, 255, 255, .98);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
    border-top: 0;
    border-bottom: 1px solid var(--ac-dados-border);
    box-shadow: 0 8px 22px rgba(23, 28, 102, .05);
    margin-top: 0 !important;
}

.ac-dados-submenu__inner {
    display: grid;
    grid-template-columns: 300px minmax(0, 1fr);
    align-items: center;
    gap: 28px;
    min-height: var(--ac-dados-submenu-height);
    padding-block: 12px;
}

.ac-dados-submenu__brand {
    width: 300px;
    max-width: 100%;
    display: inline-flex;
    align-items: center;
    justify-content: flex-end;
    text-decoration: none;
}

.ac-dados-submenu__brand img {
    width: auto;
    max-width: 100%;
    height: 44px;
    display: block;
}

.ac-dados-submenu__menu {
    min-width: 0;
}

.ac-dados-submenu__links {
    display: flex;
    align-items: center;
    justify-content: flex-start;
    gap: 12px 30px;
    list-style: none;
    margin: 0;
    padding: 0;
    flex-wrap: wrap;
}

.ac-dados-submenu__links a {
    display: inline-flex;
    align-items: center;
    min-height: 38px;
    font-weight: 500;
    font-size: 14px;
    color: var(--ac-dados-ink-2);
    text-decoration: none;
    position: relative;
    white-space: nowrap;
}

.ac-dados-submenu__links a[aria-current="page"] {
    color: var(--ac-dados-navy);
    font-weight: 700;
}

.ac-dados-submenu__links a::after {
    content: "";
    position: absolute;
    left: 0;
    right: 0;
    bottom: 2px;
    height: 2px;
    border-radius: 999px;
    background: var(--ac-dados-blue);
    transform: scaleX(0);
    transform-origin: left center;
    transition: transform .18s ease;
}

.ac-dados-submenu__links a:hover,
.ac-dados-submenu__links a:focus-visible {
    color: var(--ac-dados-navy);
}

.ac-dados-submenu__links a:hover::after,
.ac-dados-submenu__links a:focus-visible::after,
.ac-dados-submenu__links a[aria-current="page"]::after {
    transform: scaleX(1);
}

/* ------------------------------------------------------------ Dashboard */
.ac-dados-main {
    padding-block: 32px;
}

.ac-dados-dashboard {
    display: grid;
    grid-template-columns: 300px minmax(0, 1fr);
    gap: 28px;
    align-items: start;
}

.ac-dados-dashboard--full {
    grid-template-columns: minmax(0, 1fr);
}

/* ------------------------------------------------------- Cards genéricos */
.ac-dados-card {
    background: var(--ac-dados-surface);
    border: 1px solid var(--ac-dados-border);
    border-radius: var(--ac-dados-radius);
    padding: 18px;
}

.ac-dados-card__title {
    display: flex;
    align-items: center;
    gap: 7px;
    font-weight: 700;
    font-size: 13px;
    color: var(--ac-dados-ink);
    margin: 0 0 12px;
}

.ac-dados-card__eyebrow {
    font-size: 10px;
    letter-spacing: .26em;
    text-transform: uppercase;
    color: var(--ac-dados-muted);
    margin: 0 0 10px;
}

/* --------------------------------------------------------------- Sidebar */
.ac-dados-sidebar {
    position: sticky;
    top: calc(var(--ac-template-header-height) + var(--ac-dados-submenu-height) + 18px);
    display: flex;
    flex-direction: column;
    gap: 18px;
}

.ac-dados-minimap {
    margin: 0;
    background: var(--ac-dados-bg);
    border: 1px solid var(--ac-dados-border);
    border-radius: 12px;
    padding: 0;
    overflow: hidden;
}

.ac-dados-minimap__chart {
    width: 100%;
    height: 280px;
    min-height: 280px;
    display: block;
}

.ac-dados-minimap__chart canvas {
    display: block;
}

.ac-dados-uf {
    margin-top: 12px;
}

.ac-dados-uf__label {
    display: block;
    font-size: 11px;
    font-weight: 600;
    color: var(--ac-dados-muted);
    margin-bottom: 4px;
}

.ac-dados-uf__select {
    width: 100%;
    padding: 9px 12px;
    border: 1px solid var(--ac-dados-border);
    border-radius: 10px;
    background: #fff;
    font: inherit;
    font-size: 13px;
    color: var(--ac-dados-ink);
    cursor: pointer;
}

.ac-dados-uf__select:focus {
    outline: 2px solid var(--ac-dados-blue);
    outline-offset: 1px;
}

.ac-dados-uf__foot {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 8px;
    margin-top: 10px;
}

.ac-dados-uf__reset {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    background: none;
    border: 0;
    padding: 0;
    cursor: pointer;
    font: inherit;
    font-weight: 600;
    font-size: 12.5px;
    color: var(--ac-dados-blue);
}

.ac-dados-uf__note {
    font-size: 11.5px;
    color: var(--ac-dados-muted);
}

/* ---------------------------------------------------------- Dimnav */
.ac-dados-dimnav {
    display: flex;
    flex-direction: column;
    gap: 3px;
}

.ac-dados-dimnav__item {
    display: flex;
    align-items: center;
    gap: 11px;
    padding: 10px 12px;
    border-radius: 10px;
    border: 1px solid transparent;
    font-weight: 500;
    font-size: 13.5px;
    color: var(--ac-dados-ink-2);
    text-decoration: none;
}

.ac-dados-dimnav__icon {
    flex: none;
    width: 1.2em;
    font-size: 1.05em;
    text-align: center;
    color: var(--ac-dados-blue);
}

.ac-dados-dimnav__item.is-active .ac-dados-dimnav__icon {
    color: var(--ac-dados-navy);
}

.ac-dados-source {
    font-size: 12px;
    font-style: italic;
    color: var(--ac-dados-muted);
    margin: 8px 0 0;
}

.ac-dados-dimnav__item:hover {
    background: #eef1fb;
    color: var(--ac-dados-navy);
    box-shadow: inset 3px 0 0 var(--ac-dados-blue);
}

.ac-dados-dimnav__item.is-active {
    background: #eef1fb;
    color: var(--ac-dados-navy);
    font-weight: 600;
    border-color: #dbe2f6;
    box-shadow: inset 3px 0 0 var(--ac-dados-blue);
}

/* --------------------------------------------------------------- Content */
.ac-dados-content {
    min-width: 0;
    display: flex;
    flex-direction: column;
    gap: 22px;
}

.ac-dados-intro {
    font-size: 16px;
    line-height: 1.62;
    color: var(--ac-dados-ink-2);
    margin: 0 0 22px;
    max-width: none;
}

.ac-dados-intro strong {
    color: var(--ac-dados-ink);
    font-weight: 700;
}

.ac-dados-dimhead {
    margin-bottom: 14px;
}

.ac-dados-dimhead__title {
    font-weight: 300;
    font-size: 30px;
    line-height: 1.1;
    color: var(--ac-dados-ink);
    margin: 2px 0 0;
}

.ac-dados-kpis {
    list-style: none;
    margin: 0 0 22px;
    padding: 0;
    display: grid;
    grid-template-columns: repeat(6, 1fr);
    gap: 14px;
}

.ac-dados-kpi {
    background: var(--ac-dados-surface);
    border: 1px solid var(--ac-dados-border);
    border-radius: 14px;
    padding: 16px;
    display: flex;
    flex-direction: column;
    gap: 6px;
}

.ac-dados-kpi__icon {
    color: var(--ac-dados-navy);
    font-size: 20px;
    line-height: 1;
}

.ac-dados-kpi__value {
    font-weight: 300;
    font-size: 22px;
    line-height: 1.1;
    color: var(--ac-dados-ink);
}

.ac-dados-kpi__label {
    font-size: 12px;
    color: var(--ac-dados-muted);
}

.ac-dados-card__badge {
    display: inline-block;
    margin-left: 4px;
    font-weight: 700;
    color: var(--ac-dados-green);
}

.ac-dados-card__badge.is-down {
    color: #e2574c;
}

.ac-dados-card__badge small {
    font-weight: 400;
    color: var(--ac-dados-muted);
}

.ac-dados-donut {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
    gap: 18px;
    align-items: center;
}

.ac-dados-donut__chart {
    margin: 0;
}

.ac-dados-donut__legend {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 2px;
}

.ac-dados-donut__item {
    display: grid;
    grid-template-columns: 14px 1fr auto auto;
    align-items: center;
    gap: 10px;
    padding: 7px 0;
    border-bottom: 1px solid var(--ac-dados-border);
    font-size: 13px;
}

.ac-dados-donut__item:last-child {
    border-bottom: 0;
}

.ac-dados-donut__dot {
    width: 12px;
    height: 12px;
    border-radius: 4px;
}

.ac-dados-donut__name {
    color: var(--ac-dados-ink-2);
}

.ac-dados-donut__count {
    font-weight: 700;
    color: var(--ac-dados-ink);
}

.ac-dados-donut__pct {
    color: var(--ac-dados-muted);
    min-width: 44px;
    text-align: right;
}

.ac-dados-chart-card__legend {
    display: flex;
    gap: 16px;
    margin: 0;
    font-size: 12.5px;
    color: var(--ac-dados-ink-2);
    flex-wrap: wrap;
}

.ac-dados-chart-card__legend span {
    display: inline-flex;
    align-items: center;
    gap: 6px;
}

.ac-dados-chart-card__legend i {
    width: 10px;
    height: 10px;
    border-radius: 3px;
    display: inline-block;
}

.ac-dados-dimpanel {
    display: none;
}

.ac-dados-dimpanel.is-active {
    display: block;
}

.ac-dados-charts {
    display: grid;
    gap: 16px;
}

.ac-dados-chart-card {
    background: var(--ac-dados-surface);
    border: 1px solid var(--ac-dados-border);
    border-radius: var(--ac-dados-radius);
    padding: 22px 24px;
}

.ac-dados-chart-card--mini {
    padding: 18px;
}

.ac-dados-chart-card__header {
    display: flex;
    align-items: baseline;
    justify-content: space-between;
    gap: 12px;
    flex-wrap: wrap;
    margin-bottom: 10px;
}

.ac-dados-chart-card__title {
    font-weight: 700;
    font-size: 15px;
    color: var(--ac-dados-ink);
    margin: 0;
}

.ac-dados-chart-card__desc {
    font-size: 12px;
    color: var(--ac-dados-muted);
    margin: 2px 0 0;
}

.ac-dados-chart-card__value {
    font-weight: 300;
    font-size: 24px;
    color: var(--ac-dados-ink);
    margin: 0;
}

.ac-dados-chart-card__value span {
    font-size: 13px;
    color: var(--ac-dados-muted);
}

.ac-dados-chart-figure {
    margin: 0;
}

.ac-dados-chart {
    width: 100%;
    min-height: 220px;
}

.ac-dados-chart-figure figcaption {
    font-size: 11.5px;
    font-style: italic;
    color: var(--ac-dados-muted);
    margin-top: 8px;
}

.ac-dados-chart-empty,
.ac-dados-chart-card__noscript {
    font-size: 13px;
    color: var(--ac-dados-muted);
    padding: 24px 0;
    text-align: center;
}

.ac-dados-dimpanel__intro {
    padding: 34px;
}

.ac-dados-dimpanel__title {
    font-weight: 300;
    font-size: 30px;
    color: var(--ac-dados-ink);
    margin: 0 0 12px;
}

.ac-dados-dimpanel__text {
    font-size: 15px;
    line-height: 1.6;
    color: var(--ac-dados-ink-2);
    margin: 0 0 8px;
    max-width: 64ch;
}

.ac-dados-dimpanel__hint {
    font-size: 13px;
    color: var(--ac-dados-muted);
    margin: 14px 0 0;
}

/* ------------------------------------------------------------------- CTA */
.ac-dados-cta {
    padding-bottom: 56px;
}

.ac-dados-cta__band {
    position: relative;
    overflow: hidden;
    background: linear-gradient(110deg, #171c66 0%, #2c357f 55%, #3f5bb5 100%);
    border-radius: 22px;
    padding: 40px 48px;
    display: grid;
    grid-template-columns: 1fr auto;
    gap: 32px;
    align-items: center;
}

.ac-dados-cta__art {
    position: absolute;
    right: -2%;
    bottom: -40%;
    width: 46%;
    opacity: .4;
    pointer-events: none;
}

.ac-dados-cta__text,
.ac-dados-cta__action {
    position: relative;
    z-index: 2;
}

.ac-dados-cta__action {
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    gap: 8px;
}

.ac-dados-cta__info {
    font-size: 11.5px;
    color: rgba(255, 255, 255, .6);
}

.ac-dados-cta__title {
    font-weight: 300;
    font-size: 28px;
    line-height: 1.12;
    color: #fff;
    margin: 0 0 8px;
}

.ac-dados-cta__desc {
    font-size: 15px;
    line-height: 1.55;
    color: rgba(255, 255, 255, .84);
    margin: 0;
    max-width: 60ch;
}

.ac-dados-btn {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    border-radius: 999px;
    padding: 15px 30px;
    font-weight: 600;
    font-size: 15px;
    text-decoration: none;
}

.ac-dados-btn--white {
    background: #fff;
    color: var(--ac-dados-navy);
}

.ac-dados-btn--white:hover {
    background: #eef1fb;
}

/* ----------------------------------------------------------------- Fonte */
.ac-dados-fonte {
    padding-bottom: 40px;
}

.ac-dados-fonte__text {
    font-size: 12px;
    font-style: italic;
    color: var(--ac-dados-muted);
    margin: 0;
}

/* ------------------------------------------------------------ Responsivo */
@media (max-width: 1200px) {
    .ac-dados-kpis {
        grid-template-columns: repeat(3, 1fr);
    }
}

@media (max-width: 1100px) {
    .ac-dados-view {
        --ac-template-header-height: 70px;
        --ac-dados-submenu-height: 76px;
    }

    .ac-dados-submenu__inner {
        grid-template-columns: 260px minmax(0, 1fr);
        gap: 24px;
    }

    .ac-dados-submenu__brand,
    .ac-dados-submenu__brand img {
        width: 260px;
    }

    .ac-dados-dashboard {
        grid-template-columns: minmax(0, 1fr);
    }

    .ac-dados-sidebar {
        position: static;
    }

    .ac-dados-donut {
        grid-template-columns: minmax(0, 1fr);
    }
}

@media (max-width: 720px) {
    .ac-dados-view {
        --ac-template-header-height: 66px;
        --ac-dados-submenu-height: auto;
    }

    .ac-dados-container {
        width: min(100% - 32px, var(--ac-dados-max-width));
    }

    .ac-dados-header__nav {
        display: none;
    }

    .ac-dados-submenu {
        top: var(--ac-template-header-height);
    }

    .ac-dados-submenu__inner {
        grid-template-columns: minmax(0, 1fr);
        gap: 12px;
        min-height: auto;
        padding-block: 12px;
    }

    .ac-dados-submenu__brand,
    .ac-dados-submenu__brand img {
        width: 220px;
    }

    .ac-dados-submenu__links {
        gap: 8px 18px;
    }

    .ac-dados-submenu__links a {
        min-height: 32px;
        font-size: 13px;
    }

    .ac-dados-kpis {
        grid-template-columns: repeat(2, 1fr);
    }

    .ac-dados-cta__band {
        grid-template-columns: 1fr;
        padding: 28px 24px;
    }
}