/**
 * stats.css — Composants de statistiques partagés (sans Chart.js)
 * Utilisé par les plugins qui affichent des statistiques (ResourceManager, etc.)
 */

/* ---------------------------------------------------------------
   Cards de synthèse
--------------------------------------------------------------- */
.stats-card {
    border-radius: .5rem;
    padding: 1.25rem 1rem;
    text-align: center;
    color: #fff;
    height: 100%;
}

.stats-card--primary  { background: linear-gradient(135deg, #4361ee, #3a0ca3); }
.stats-card--success  { background: linear-gradient(135deg, #2dc653, #1a7431); }
.stats-card--warning  { background: linear-gradient(135deg, #f4a261, #e76f51); }
.stats-card--info     { background: linear-gradient(135deg, #4cc9f0, #4361ee); }

.stats-card__icon {
    font-size: 1.8rem;
    opacity: .85;
    margin-bottom: .4rem;
}

.stats-card__value {
    font-size: 2rem;
    font-weight: 700;
    line-height: 1.1;
}

.stats-card__label {
    font-size: .8rem;
    opacity: .9;
    margin-top: .25rem;
    text-transform: uppercase;
    letter-spacing: .04em;
}

/* ---------------------------------------------------------------
   Barres de progression
--------------------------------------------------------------- */
.stats-bar__label {
    display: flex;
    justify-content: space-between;
    font-size: .85rem;
    margin-bottom: .2rem;
}

.stats-bar__count {
    font-weight: 600;
    color: var(--bs-secondary, #6c757d);
}

.stats-bar__track {
    height: 10px;
    background: var(--bs-light, #f8f9fa);
    border-radius: 5px;
    overflow: hidden;
    border: 1px solid var(--bs-border-color, #dee2e6);
}

.stats-bar__track--sm {
    height: 6px;
}

.stats-bar__fill {
    height: 100%;
    border-radius: 5px;
    transition: width .4s ease;
}

.stats-bar__fill--primary   { background: #4361ee; }
.stats-bar__fill--secondary { background: #6c757d; }
.stats-bar__fill--success   { background: #2dc653; }
.stats-bar__fill--warning   { background: #f4a261; }
.stats-bar__fill--info      { background: #4cc9f0; }

/* ---------------------------------------------------------------
   Classements
--------------------------------------------------------------- */
.stats-ranking-item {
    display: flex;
    align-items: center;
    gap: .75rem;
    padding: .6rem 1rem;
}

.stats-ranking-item--even {
    background: var(--bs-light, #f8f9fa);
}

.stats-ranking-item__rank {
    width: 1.6rem;
    height: 1.6rem;
    border-radius: 50%;
    background: var(--bs-primary, #4361ee);
    color: #fff;
    font-size: .75rem;
    font-weight: 700;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}

.stats-ranking-item__body {
    flex: 1;
    min-width: 0;
}

.stats-ranking-item__title {
    font-weight: 600;
    font-size: .9rem;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    display: block;
    color: inherit;
    text-decoration: none;
}

.stats-ranking-item__title:hover {
    text-decoration: underline;
}

.stats-ranking-item__value {
    font-size: .85rem;
    font-weight: 600;
    white-space: nowrap;
    color: var(--bs-secondary, #6c757d);
}

/* ---------------------------------------------------------------
   Étoiles
--------------------------------------------------------------- */
.stats-stars__filled { color: #f4a261; }
.stats-stars__empty  { color: var(--bs-border-color, #dee2e6); }

/* ---------------------------------------------------------------
   Tags / badges de contributeurs
--------------------------------------------------------------- */
.stats-tags {
    display: flex;
    flex-wrap: wrap;
    gap: .5rem;
}

.stats-tag {
    display: inline-flex;
    align-items: center;
    gap: .35rem;
    background: var(--bs-light, #f8f9fa);
    border: 1px solid var(--bs-border-color, #dee2e6);
    border-radius: 2rem;
    padding: .25rem .75rem;
    font-size: .85rem;
}

.stats-tag__count {
    background: var(--bs-primary, #4361ee);
    color: #fff;
    border-radius: 1rem;
    padding: .05rem .45rem;
    font-size: .75rem;
    font-weight: 700;
}

/* ---------------------------------------------------------------
   Admin-style soft cards (overlay, adapts to light/dark theme)
   Usage: <div class="card stats-card--soft stats-card--soft-primary">
--------------------------------------------------------------- */
.stats-card--soft {
    border: 1px solid var(--bs-border-color) !important;
    transition: transform .2s ease, box-shadow .2s ease;
    position: relative;
    overflow: hidden;
}

.stats-card--soft::before {
    content: '';
    position: absolute;
    inset: 0;
    opacity: .1;
    pointer-events: none;
}

.stats-card--soft:hover {
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(0,0,0,.15);
}

.stats-card--soft-primary::before  { background: linear-gradient(135deg, var(--bs-primary), rgba(var(--bs-primary-rgb),.5)); }
.stats-card--soft-success::before  { background: linear-gradient(135deg, var(--bs-success), rgba(var(--bs-success-rgb),.5)); }
.stats-card--soft-warning::before  { background: linear-gradient(135deg, var(--bs-warning), rgba(var(--bs-warning-rgb),.5)); }
.stats-card--soft-info::before     { background: linear-gradient(135deg, var(--bs-info),    rgba(var(--bs-info-rgb),.5)); }
.stats-card--soft-danger::before   { background: linear-gradient(135deg, var(--bs-danger),  rgba(var(--bs-danger-rgb),.5)); }

.stats-card--soft__title {
    color: var(--bs-body-color) !important;
    font-weight: 600;
    font-size: .875rem;
    position: relative;
    z-index: 1;
}

.stats-card--soft__value {
    color: var(--bs-body-color) !important;
    font-weight: 700;
    position: relative;
    z-index: 1;
}

.stats-card--soft__pct {
    color: var(--bs-secondary-color) !important;
    font-weight: 600;
    position: relative;
    z-index: 1;
}

.stats-card--soft__icon {
    opacity: .3;
    position: relative;
    z-index: 1;
    transition: opacity .3s ease, transform .3s ease;
}

.stats-card--soft-primary .stats-card--soft__icon { color: var(--bs-primary); }
.stats-card--soft-success .stats-card--soft__icon { color: var(--bs-success); }
.stats-card--soft-warning .stats-card--soft__icon { color: var(--bs-warning); }
.stats-card--soft-info    .stats-card--soft__icon { color: var(--bs-info); }

.stats-card--soft:hover .stats-card--soft__icon {
    opacity: .5;
    transform: scale(1.1);
}

[data-bs-theme="dark"] .stats-card--soft,
.theme-dark .stats-card--soft {
    background-color: var(--bs-body-bg) !important;
    border-color: var(--bs-border-color) !important;
}

[data-bs-theme="dark"] .stats-card--soft::before,
.theme-dark .stats-card--soft::before { opacity: .2; }

/* ---------------------------------------------------------------
   Period stat boxes  (compact icon + number + label)
--------------------------------------------------------------- */
.stats-period-box {
    padding: 1rem;
    transition: transform .3s ease;
}

.stats-period-box:hover { transform: scale(1.05); }

.stats-period-box__icon { margin-bottom: .5rem; }

/* ---------------------------------------------------------------
   Vertical column chart  (hourly distribution, etc.)
   Usage: <div class="stats-vchart"> … <div class="stats-vchart__col">
            <div class="stats-vchart__label">00h</div>
            <div class="stats-vchart__track">
              <div class="stats-vchart__fill" style="height:60%">
                <span class="stats-vchart__value">12</span>
              </div>
            </div>
          </div> …
--------------------------------------------------------------- */
.stats-vchart {
    display: flex;
    justify-content: space-between;
    align-items: flex-end;
    height: 200px;
    gap: 2px;
}

.stats-vchart__col {
    flex: 1;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: flex-end;
    min-width: 0;
}

.stats-vchart__label {
    font-size: .65rem;
    color: var(--bs-secondary-color, #6c757d);
    margin-bottom: 4px;
}

.stats-vchart__track {
    width: 100%;
    height: 150px;
    display: flex;
    align-items: flex-end;
    justify-content: center;
}

.stats-vchart__fill {
    width: 80%;
    background: linear-gradient(to top, #0d6efd, #0dcaf0);
    border-radius: 4px 4px 0 0;
    position: relative;
    transition: height .4s ease;
    min-height: 2px;
}

.stats-vchart__fill--peak {
    background: linear-gradient(to top, #dc3545, #fd7e14);
}

.stats-vchart__fill:hover { opacity: .8; transform: scaleY(1.05); }

.stats-vchart__value {
    position: absolute;
    bottom: 5px;
    left: 50%;
    transform: translateX(-50%);
    font-size: .7rem;
    font-weight: 700;
    color: #fff;
    white-space: nowrap;
    text-shadow: 0 1px 2px rgba(0,0,0,.5);
    opacity: 0;
    transition: opacity .3s ease;
}

.stats-vchart__fill:hover .stats-vchart__value { opacity: 1; }

@media (max-width: 768px) {
    .stats-vchart__label  { font-size: .55rem; }
    .stats-vchart__value  { font-size: .6rem; }
}

/* ---------------------------------------------------------------
   Activity timeline  (horizontal bars with date label)
   Usage: <div class="stats-activity">
            <div class="stats-activity__item">
              <div class="stats-activity__date">01/01<br><small>Mon</small></div>
              <div class="stats-activity__track">
                <div class="stats-activity__bar" style="width:60%">
                  <span class="stats-activity__value">4</span>
                </div>
              </div>
            </div>
          </div>
--------------------------------------------------------------- */
.stats-activity {
    max-height: 400px;
    overflow-y: auto;
    scrollbar-width: thin;
    scrollbar-color: #888 transparent;
}

.stats-activity::-webkit-scrollbar       { width: 8px; }
.stats-activity::-webkit-scrollbar-track { background: transparent; border-radius: 4px; }
.stats-activity::-webkit-scrollbar-thumb { background: #888; border-radius: 4px; }
.stats-activity::-webkit-scrollbar-thumb:hover { background: #555; }

.stats-activity__item {
    display: flex;
    align-items: center;
    margin-bottom: .5rem;
    padding: .25rem 0;
}

.stats-activity__date {
    width: 80px;
    text-align: right;
    padding-right: 1rem;
    flex-shrink: 0;
}

.stats-activity__track {
    flex: 1;
    background: var(--bs-light, #e9ecef);
    border-radius: 4px;
    height: 24px;
    position: relative;
    overflow: hidden;
}

.stats-activity__bar {
    height: 100%;
    background: linear-gradient(to right, #0d6efd, #0dcaf0);
    border-radius: 4px;
    display: flex;
    align-items: center;
    padding: 0 8px;
    transition: width .5s ease;
    min-width: 30px;
}

.stats-activity__value {
    color: #fff;
    font-size: .75rem;
    font-weight: 700;
    text-shadow: 0 1px 2px rgba(0,0,0,.2);
}

[data-bs-theme="dark"] .stats-activity__track,
.theme-dark .stats-activity__track {
    background: rgba(255,255,255,.1);
}

/* ---------------------------------------------------------------
   Dark mode
--------------------------------------------------------------- */
[data-bs-theme="dark"] .stats-bar__track,
.theme-dark .stats-bar__track {
    background: rgba(255,255,255,.08);
    border-color: rgba(255,255,255,.12);
}

[data-bs-theme="dark"] .stats-ranking-item--even,
.theme-dark .stats-ranking-item--even {
    background: rgba(255,255,255,.04);
}

[data-bs-theme="dark"] .stats-tag,
.theme-dark .stats-tag {
    background: rgba(255,255,255,.06);
    border-color: rgba(255,255,255,.12);
}
