/* ======================
   WAB STATISTICS BLOCKS
   Counters, Progress, Pie, Bar, Line
   ====================== */

/* ── Shared ── */
.wab-stat-counters,
.wab-stat-progress,
.wab-stat-pie,
.wab-stat-bar,
.wab-stat-line {
    margin: 2em 0;
}

/* ── Counters ── */
.wab-stat-counters {
    display: grid;
    grid-template-columns: repeat(var(--wab-sc-cols, 4), 1fr);
    gap: 20px;
}

.wab-stat-counters__item {
    text-align: var(--wab-sc-align, left);
    padding: 0;
    background: #f1f3f5;
    border: var(--wab-sc-border, none);
    border-radius: var(--wab-sc-radius, 16px);
    position: relative;
    overflow: hidden;
    transition: box-shadow 0.25s ease;
}

.wab-stat-counters__item:hover {
    box-shadow: 0 4px 20px rgba(0,0,0,0.06);
}

.wab-stat-counters--transparent .wab-stat-counters__item:hover {
    box-shadow: none;
}

/* Gradient bar flush to top of card */
.wab-stat-counters__bar {
    height: 5px;
    border-radius: 0;
}

.wab-stat-counters--no-bar .wab-stat-counters__bar {
    display: none;
}

.wab-stat-counters__item-body {
    padding: 28px 32px;
}

.wab-stat-counters__value {
    font-size: var(--wab-sc-value-size, 42px);
    font-weight: 300;
    line-height: 1;
    font-variant-numeric: tabular-nums;
    color: var(--wab-sc-value-color, var(--wab-p-color, #374151));
}

/* Default — small superscript prefix/suffix */
.wab-stat-counters--affix-super .wab-stat-counters__prefix,
.wab-stat-counters--affix-super .wab-stat-counters__suffix {
    font-size: 0.55em;
    font-weight: 400;
    color: var(--wab-sc-label-color, var(--wab-gray-400, #9ca3af));
    vertical-align: super;
}
.wab-stat-counters--affix-super .wab-stat-counters__prefix { margin-right: 1px; }
.wab-stat-counters--affix-super .wab-stat-counters__suffix { margin-left: 1px; }

/* Plain — same size and color as value */
.wab-stat-counters--affix-plain .wab-stat-counters__prefix,
.wab-stat-counters--affix-plain .wab-stat-counters__suffix {
    font-size: inherit;
    font-weight: inherit;
    color: inherit;
    vertical-align: baseline;
}
.wab-stat-counters--affix-plain .wab-stat-counters__prefix { margin-right: 2px; }
.wab-stat-counters--affix-plain .wab-stat-counters__suffix { margin-left: 2px; }

/* Legacy selector kept for backwards compatibility with old saved blocks */
.wab-stat-counters__suffix {
    font-size: 0.55em;
    font-weight: 400;
    color: var(--wab-sc-label-color, var(--wab-gray-400, #9ca3af));
    vertical-align: super;
    margin-left: 1px;
}
.wab-stat-counters--affix-plain .wab-stat-counters__suffix {
    font-size: inherit;
    font-weight: inherit;
    color: inherit;
    vertical-align: baseline;
}

.wab-stat-counters__label {
    font-size: var(--wab-sc-label-size, 14px);
    color: var(--wab-sc-label-color, var(--wab-gray-400, #9ca3af));
    margin-top: 8px;
    font-weight: 400;
}

@media (max-width: 600px) {
    .wab-stat-counters {
        grid-template-columns: repeat(2, 1fr);
    }
    .wab-stat-counters__value {
        font-size: calc(var(--wab-sc-value-size, 42px) * 0.76);
    }
}

/* ── Progress — Linear ── */
.wab-stat-progress--linear {
    background: var(--wab-gray-50);
    border-radius: 12px;
    padding: 20px;
    max-width: 500px;
}

.wab-stat-progress__bar-row {
    margin-bottom: 16px;
}

.wab-stat-progress__bar-row:last-child {
    margin-bottom: 0;
}

.wab-stat-progress__bar-header {
    display: flex;
    justify-content: space-between;
    font-size: 15px;
    margin-bottom: 6px;
}

.wab-stat-progress__bar-label {
    font-weight: 600;
    color: var(--wab-gray-900);
}

.wab-stat-progress__bar-value {
    font-weight: 700;
}

.wab-stat-progress__bar-track {
    height: 8px;
    background: var(--wab-gray-200);
    border-radius: 4px;
    overflow: hidden;
}

.wab-stat-progress__bar-fill {
    height: 100%;
    width: 0%;
    border-radius: 4px;
    transition: width 1.5s cubic-bezier(0.22, 1, 0.36, 1);
}

/* ── Progress — Circular ── */
.wab-stat-progress--circular {
    display: flex;
    justify-content: center;
    gap: 32px;
    flex-wrap: wrap;
    background: var(--wab-gray-50);
    border-radius: 12px;
    padding: 20px;
}

.wab-stat-progress__ring {
    text-align: center;
}

.wab-stat-progress__circle {
    transition: stroke-dashoffset 1.5s cubic-bezier(0.22, 1, 0.36, 1);
}

.wab-stat-progress__label {
    font-size: 12px;
    color: var(--wab-gray-500);
    margin-top: 6px;
    font-weight: 500;
}

/* ── Pie Chart ── */
.wab-stat-pie {
    background: var(--wab-gray-50);
    border-radius: 12px;
    padding: 20px;
    text-align: center;
}

.wab-stat-pie__title {
    font-size: 16px;
    font-weight: 700;
    color: var(--wab-gray-900);
    margin-bottom: 16px;
}

.wab-stat-pie__svg {
    display: block;
    margin: 0 auto;
}

.wab-stat-pie__hole {
    fill: var(--wab-gray-50);
}

.wab-stat-pie__legend {
    display: flex;
    justify-content: center;
    gap: 14px;
    margin-top: 14px;
    flex-wrap: wrap;
}

.wab-stat-pie__legend-item {
    font-size: 12px;
    display: flex;
    align-items: center;
    gap: 5px;
    color: var(--wab-gray-600);
}

.wab-stat-pie__legend-dot {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    display: inline-block;
    flex-shrink: 0;
}

/* ── Bar Chart ── */
.wab-stat-bar {
    background: var(--wab-gray-50);
    border-radius: 12px;
    padding: 20px;
    text-align: center;
}

.wab-stat-bar__title {
    font-size: 16px;
    font-weight: 700;
    color: var(--wab-gray-900);
    margin-bottom: 12px;
}

.wab-stat-bar__rect {
    transition: y 1.2s cubic-bezier(0.22, 1, 0.36, 1),
                height 1.2s cubic-bezier(0.22, 1, 0.36, 1);
}

/* ── Line Chart ── */
.wab-stat-line {
    background: var(--wab-gray-50);
    border-radius: 12px;
    padding: 20px;
}

.wab-stat-line__title {
    font-size: 16px;
    font-weight: 700;
    color: var(--wab-gray-900);
    margin-bottom: 16px;
    text-align: center;
}

.wab-stat-line__path {
    transition: stroke-dashoffset 2s cubic-bezier(0.22, 1, 0.36, 1);
}

.wab-stat-line__dot {
    transition: opacity 0.4s ease;
}

.wab-stat-line__legend {
    display: flex;
    justify-content: center;
    gap: 18px;
    margin-top: 14px;
}

.wab-stat-line__legend-item {
    font-size: 12px;
    display: flex;
    align-items: center;
    gap: 6px;
    color: var(--wab-gray-600);
}

.wab-stat-line__legend-line {
    width: 14px;
    height: 3px;
    border-radius: 2px;
    display: inline-block;
    flex-shrink: 0;
}

/* ── Dark mode ── */
html.wab-dark .wab-stat-counters__item,
html.wab-dark .wab-stat-progress,
html.wab-dark .wab-stat-pie,
html.wab-dark .wab-stat-bar,
html.wab-dark .wab-stat-line {
    background: var(--wab-gray-100);
}

html.wab-dark .wab-stat-pie__hole {
    fill: var(--wab-gray-100);
}

html.wab-dark .wab-stat-progress__bar-track {
    background: var(--wab-gray-300);
}

/* ── No-animation fallback ──
   When data-wab-animate is absent, show final state immediately */
.wab-stat-progress__bar-fill:not([style*="width: 0"]) { transition: none; }

.wab-stat-counters:not([data-wab-animate]) .wab-stat-counters__value,
.wab-stat-progress:not([data-wab-animate]) .wab-stat-progress__bar-fill,
.wab-stat-progress:not([data-wab-animate]) .wab-stat-progress__circle,
.wab-stat-bar:not([data-wab-animate]) .wab-stat-bar__rect,
.wab-stat-line:not([data-wab-animate]) .wab-stat-line__path,
.wab-stat-line:not([data-wab-animate]) .wab-stat-line__dot,
.wab-stat-pie:not([data-wab-animate]) {
    transition: none !important;
}

/* Progress bars: show full width immediately when no animation */
.wab-stat-progress:not([data-wab-animate]) .wab-stat-progress__bar-fill {
    width: var(--target-width) !important;
}

/* Line dots: show immediately */
.wab-stat-line:not([data-wab-animate]) .wab-stat-line__dot {
    opacity: 1 !important;
}

/* Line paths: show immediately */
.wab-stat-line:not([data-wab-animate]) .wab-stat-line__path {
    stroke-dashoffset: 0 !important;
}
