/* ============================================================
   Stats page — Howl of Eternity community dashboard.
   Standalone stylesheet loaded only on /statistiky.
   Uses the existing CSS variables from style.css (--gold, --bg-card, etc).
   ============================================================ */

.stats-page {
  max-width: 1100px;
  margin: 0 auto;
  padding: 2rem 1.25rem 4rem;
  color: var(--text);
}

.stats-hero {
  text-align: center;
  margin-bottom: 2rem;
}
.stats-hero__crest {
  font-size: 1.6rem; letter-spacing: .35em; color: var(--gold);
  margin-bottom: .35rem; line-height: 1;
}
.stats-hero__title {
  font-family: 'Cinzel', serif;
  font-size: clamp(2rem, 5vw, 2.8rem);
  color: var(--gold-light);
  text-transform: uppercase; letter-spacing: .05em;
  text-shadow: 0 0 24px rgba(201,162,39,0.18);
  margin: .25rem 0;
}
.stats-hero__sub {
  font-family: 'Crimson Text', serif;
  color: var(--text-muted);
  font-size: 1.1rem;
  font-style: italic;
}

/* ---------- KPI row ---------- */
.stats-kpis {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 1rem;
  margin-bottom: 2.2rem;
}
.kpi-card {
  background:
    radial-gradient(ellipse at 50% 0%, rgba(201,162,39,0.10) 0%, transparent 70%),
    linear-gradient(180deg, #100b16 0%, #0a0810 100%);
  border: 1px solid var(--border-dim);
  border-radius: var(--radius);
  padding: 1.2rem 1rem;
  text-align: center;
  box-shadow: 0 2px 18px rgba(0,0,0,0.35);
  position: relative;
  overflow: hidden;
}
.kpi-card::before {
  content: ""; position: absolute; top: 0; left: 10%; right: 10%; height: 1px;
  background: linear-gradient(90deg, transparent, var(--gold), transparent);
  opacity: .6;
}
.kpi-card__icon {
  font-size: 1.5rem; color: var(--gold); margin-bottom: .25rem; line-height: 1;
}
.kpi-card__value {
  font-family: 'Cinzel', serif;
  font-size: 2.2rem;
  color: var(--gold-light);
  line-height: 1.1;
  text-shadow: 0 0 18px rgba(201,162,39,0.25);
}
.kpi-card__label {
  font-family: 'Crimson Text', serif;
  font-size: .95rem;
  color: var(--text-muted);
  margin-top: .3rem;
  letter-spacing: .03em;
}

/* ---------- Grid + cards ---------- */
.stats-grid-2 {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
  gap: 1.2rem;
  margin-bottom: 1.5rem;
}
.stats-card {
  background:
    linear-gradient(180deg, rgba(201,162,39,0.04), transparent),
    var(--bg-card);
  border: 1px solid var(--border-dim);
  border-radius: var(--radius);
  padding: 1.2rem 1.3rem 1.1rem;
  box-shadow: 0 2px 14px rgba(0,0,0,0.3);
}
.stats-card__title {
  font-family: 'Cinzel', serif;
  color: var(--gold-light);
  font-size: 1.15rem;
  letter-spacing: .04em;
  margin: 0 0 1rem;
  display: flex; align-items: center; gap: .55rem;
}
.stats-card__title-icon { color: var(--gold); }
.stats-card--wide { grid-column: 1 / -1; }

/* ---------- Bar chart (race / class) ---------- */
.barchart { list-style: none; margin: 0; padding: 0; }
.barchart__row {
  display: grid;
  grid-template-columns: minmax(95px, 28%) 1fr auto;
  align-items: center;
  gap: .6rem;
  padding: .35rem 0;
  font-family: 'Crimson Text', serif;
  font-size: .98rem;
}
.barchart__label {
  color: var(--text);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.barchart__track {
  background: rgba(255,255,255,0.04);
  border-radius: 999px;
  overflow: hidden;
  height: 14px;
  position: relative;
}
.barchart__fill {
  height: 100%;
  background: linear-gradient(90deg, var(--gold) 0%, #f0d674 100%);
  border-radius: 999px;
  width: 0;
  animation: barchart-grow 1s cubic-bezier(.2,.7,.3,1) forwards;
  box-shadow: 0 0 12px rgba(201,162,39,.35) inset;
}
@keyframes barchart-grow {
  from { width: 0; }
  to   { width: var(--bar-w, 0%); }
}
.barchart__count {
  color: var(--gold-light);
  font-variant-numeric: tabular-nums;
  font-size: .92rem;
  min-width: 2.5rem;
  text-align: right;
}
.barchart__pct {
  color: var(--text-muted);
  font-size: .82rem;
  margin-left: .2rem;
}

/* ---------- Drill-down details ---------- */
.subrace-details { margin-top: .4rem; }
.subrace-details > summary {
  cursor: pointer;
  padding: .3rem .5rem;
  font-family: 'Crimson Text', serif;
  font-size: .9rem;
  color: var(--text-muted);
  border: 1px dashed var(--border-dim);
  border-radius: var(--radius);
  list-style: none;
}
.subrace-details > summary:hover { color: var(--gold-light); }
.subrace-details[open] > summary { color: var(--gold-light); }
.subrace-details > summary::-webkit-details-marker { display: none; }
.subrace-details > summary::before {
  content: "▸ "; color: var(--gold); transition: transform .2s;
  display: inline-block;
}
.subrace-details[open] > summary::before { content: "▾ "; }
.subrace-list {
  list-style: none;
  margin: .6rem 0 0;
  padding-left: 1rem;
  border-left: 2px solid var(--border-dim);
}
.subrace-list li {
  padding: .25rem 0;
  font-size: .9rem;
  display: flex; justify-content: space-between;
  color: var(--text-muted);
}
.subrace-list li b { color: var(--gold-light); font-weight: normal; }
.subrace-list li.subrace-list__heritage {
  display: block;
  padding: .15rem 0 .15rem .5rem;
}
.subrace-details--nested > summary {
  font-size: .8rem;
  color: var(--text-muted);
  padding: .15rem 0;
}
.stats-card__hint {
  margin: 0 0 .6rem;
  font-size: .82rem;
  color: var(--text-muted);
  font-style: italic;
}

/* ---------- Donut (magic vs steel) ---------- */
.donut-wrap {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 1.4rem;
  flex-wrap: wrap;
}
.donut {
  --pct: 0;
  width: 160px; height: 160px;
  border-radius: 50%;
  background: conic-gradient(
    var(--gold) 0% calc(var(--pct) * 1%),
    #2a1f3a calc(var(--pct) * 1%) 100%
  );
  display: grid; place-items: center;
  position: relative;
  box-shadow: 0 0 24px rgba(201,162,39,.18);
}
.donut::before {
  content: ""; position: absolute; inset: 14px;
  background: #0a0810; border-radius: 50%;
  box-shadow: inset 0 0 12px rgba(0,0,0,.5);
}
.donut__center {
  position: relative; z-index: 1;
  text-align: center;
  font-family: 'Cinzel', serif;
}
.donut__pct {
  font-size: 1.8rem; color: var(--gold-light); line-height: 1;
}
.donut__caption {
  font-size: .8rem; color: var(--text-muted); margin-top: .2rem;
}
.donut-legend {
  display: grid; gap: .6rem;
  font-family: 'Crimson Text', serif;
}
.donut-legend__row {
  display: flex; align-items: center; gap: .55rem;
  font-size: .95rem; color: var(--text);
}
.donut-legend__swatch {
  width: 14px; height: 14px; border-radius: 3px; flex: 0 0 14px;
}
.donut-legend__swatch--magic   { background: var(--gold); }
.donut-legend__swatch--steel   { background: #2a1f3a; border: 1px solid var(--border-dim); }
.donut-legend__swatch--mage    { background: #6a4cb5; }
.donut-legend__swatch--fighter { background: #c9a227; }
.donut-legend__swatch--spy     { background: #2f8f7a; }
.donut.donut--tri {
  background: conic-gradient(
    #6a4cb5 0%               var(--mage-end, 0%),
    #c9a227 var(--mage-end, 0%)    var(--fighter-end, 0%),
    #2f8f7a var(--fighter-end, 0%) 100%
  );
}
.donut-legend__count {
  margin-left: auto; color: var(--gold-light); font-variant-numeric: tabular-nums;
}

/* ---------- Combos (ranked race × class) ---------- */
.combo-list { list-style: none; padding: 0; margin: 0; counter-reset: combo; }
.combo-list li {
  display: grid;
  grid-template-columns: 2rem 1fr auto;
  align-items: center;
  gap: .8rem;
  padding: .55rem .25rem;
  border-bottom: 1px dashed rgba(255,255,255,0.05);
  font-family: 'Crimson Text', serif;
  counter-increment: combo;
}
.combo-list li:last-child { border-bottom: none; }
.combo-list li::before {
  content: counter(combo);
  font-family: 'Cinzel', serif;
  color: var(--gold);
  text-align: center;
  font-size: 1rem;
  opacity: .9;
}
.combo-list li:nth-child(1)::before { color: #f5d76e; font-size: 1.25rem; }
.combo-list li:nth-child(2)::before { color: #d4d4d4; font-size: 1.1rem; }
.combo-list li:nth-child(3)::before { color: #cd9b6e; font-size: 1.05rem; }
.combo-list__name { color: var(--text); }
.combo-list__name b { color: var(--gold-light); font-weight: normal; }
.combo-list__count {
  color: var(--gold-light);
  font-variant-numeric: tabular-nums;
  font-size: .95rem;
}

/* ---------- SVG line chart (timeline) ---------- */
.timeline-chart {
  width: 100%; height: 160px;
  display: block;
  overflow: visible;
}
.timeline-chart .area {
  fill: url(#timelineGradient);
  opacity: .55;
}
.timeline-chart .line {
  fill: none;
  stroke: var(--gold);
  stroke-width: 2;
  stroke-linejoin: round;
  filter: drop-shadow(0 0 6px rgba(201,162,39,.4));
}
.timeline-chart .dot {
  fill: var(--gold-light);
  stroke: #0a0810;
  stroke-width: 1.5;
}
.timeline-chart .grid {
  stroke: rgba(255,255,255,0.06);
  stroke-width: 1;
}
.timeline-chart .axis-label {
  fill: var(--text-muted);
  font-size: 10px;
  font-family: 'Crimson Text', serif;
}

/* ---------- Day-of-week heatmap ---------- */
.dow-grid {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: .35rem;
  align-items: end;
  height: 100px;
}
.dow-bar {
  display: flex; flex-direction: column;
  justify-content: flex-end; align-items: center;
  height: 100%;
}
.dow-bar__fill {
  width: 100%;
  background: linear-gradient(180deg, #f0d674, var(--gold) 70%, #8a6e1c);
  border-radius: 4px 4px 0 0;
  height: 0;
  animation: dowbar-grow .9s ease-out forwards;
  box-shadow: 0 0 8px rgba(201,162,39,.3);
}
@keyframes dowbar-grow {
  from { height: 0; }
  to { height: var(--dow-h, 0%); }
}
.dow-bar__label {
  margin-top: .3rem;
  font-family: 'Cinzel', serif;
  font-size: .75rem;
  color: var(--text-muted);
  letter-spacing: .05em;
}
.dow-bar__count {
  font-size: .7rem; color: var(--gold-light);
  margin-bottom: .15rem;
  font-variant-numeric: tabular-nums;
}

/* ---------- Attributes radar/bars ---------- */
.attr-grid {
  display: grid; gap: .6rem;
}
.attr-row {
  display: grid;
  grid-template-columns: 100px 1fr auto;
  align-items: center;
  gap: .6rem;
  font-family: 'Crimson Text', serif;
}
.attr-row__label { color: var(--text); font-size: .95rem; }
.attr-row__track {
  background: rgba(255,255,255,0.04);
  border-radius: 6px;
  height: 12px;
  position: relative;
}
.attr-row__fill {
  height: 100%;
  background: linear-gradient(90deg, #8a6e1c, var(--gold));
  border-radius: 6px;
  width: 0;
  animation: barchart-grow 1.2s ease-out forwards;
}
.attr-row__value {
  font-family: 'Cinzel', serif;
  color: var(--gold-light);
  font-variant-numeric: tabular-nums;
  font-size: 1rem;
}

/* ---------- Recent feed ---------- */
.recent-feed { list-style: none; padding: 0; margin: 0; }
.recent-feed li {
  display: flex; align-items: center; gap: .6rem;
  padding: .5rem .25rem;
  border-bottom: 1px dashed rgba(255,255,255,0.05);
  font-family: 'Crimson Text', serif;
  font-size: .92rem;
}
.recent-feed li:last-child { border-bottom: none; }
.recent-feed__dot {
  width: 8px; height: 8px; border-radius: 50%;
  background: var(--gold); flex: 0 0 8px;
  box-shadow: 0 0 6px rgba(201,162,39,.6);
}
.recent-feed__text { color: var(--text); }
.recent-feed__text b { color: var(--gold-light); font-weight: normal; }
.recent-feed__time {
  margin-left: auto; color: var(--text-muted); font-size: .8rem;
  font-variant-numeric: tabular-nums;
}

/* ---------- Insights ---------- */
.insights {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-content: flex-start;
  gap: .7rem;
}
/* Each insight gets a comfortable target width but is allowed to shrink.
   Cards never stretch the full row — they pack into the center. */
.insights .insight {
  flex: 0 1 280px;
  max-width: 360px;
  min-width: 240px;
}
@media (max-width: 560px) {
  .insights .insight { flex: 1 1 100%; max-width: 100%; }
}
.insight {
  background: rgba(201,162,39,0.04);
  border: 1px solid var(--border-dim);
  border-left: 3px solid var(--gold);
  border-radius: var(--radius);
  padding: .9rem 1rem;
  font-family: 'Crimson Text', serif;
  font-size: .95rem;
  color: var(--text);
  line-height: 1.5;
  display: flex;
  gap: .65rem;
  align-items: flex-start;
  transition: transform .2s ease, border-color .2s ease, background .2s ease;
}
.insight:hover {
  transform: translateY(-1px);
  border-color: rgba(201,162,39,0.35);
  background: rgba(201,162,39,0.07);
}
.insight b { color: var(--gold-light); font-weight: normal; }
.insight__icon {
  flex: 0 0 auto;
  font-size: 1.15rem;
  line-height: 1.3;
  color: var(--gold);
  filter: drop-shadow(0 0 4px rgba(201,162,39,0.35));
}
.insight__text { flex: 1; }

/* ---------- Insights carousel ---------- */
.insights-carousel { padding-bottom: 1.3rem; }
.insights-carousel__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: .6rem;
  margin-bottom: 1rem;
}
.insights-carousel__controls {
  display: flex; align-items: center; gap: .35rem;
  font-family: 'Cinzel', serif;
}
.insights-carousel__btn {
  background: linear-gradient(180deg, rgba(201,162,39,0.10), rgba(201,162,39,0.02));
  border: 1px solid var(--border-dim);
  color: var(--gold-light);
  width: 2rem; height: 2rem;
  border-radius: 50%;
  font-size: 1.2rem;
  line-height: 1;
  cursor: pointer;
  display: grid; place-items: center;
  transition: background .18s ease, border-color .18s ease, transform .18s ease;
}
.insights-carousel__btn:hover {
  background: linear-gradient(180deg, rgba(201,162,39,0.22), rgba(201,162,39,0.06));
  border-color: var(--gold);
  transform: scale(1.05);
}
.insights-carousel__btn:active { transform: scale(.95); }
.insights-carousel__counter {
  font-size: .85rem;
  color: var(--text-muted);
  letter-spacing: .08em;
  min-width: 3rem;
  text-align: center;
}
.insights-carousel__counter [data-current] { color: var(--gold-light); }
.insights-carousel__viewport {
  position: relative;
  overflow: hidden;
  min-height: 6rem;
}
.insights-carousel__track {
  position: relative;
}
.insights-carousel__page {
  display: none;
  animation: insight-fade .35s ease both;
}
.insights-carousel__page.is-active { display: block; }
@keyframes insight-fade {
  from { opacity: 0; transform: translateY(4px); }
  to   { opacity: 1; transform: translateY(0); }
}
.insights-carousel__dots {
  display: flex; justify-content: center; gap: .4rem;
  margin-top: 1rem;
}
.insights-carousel__dot {
  width: 8px; height: 8px; border-radius: 50%;
  border: none;
  background: rgba(201,162,39,0.25);
  cursor: pointer;
  padding: 0;
  transition: background .18s ease, transform .18s ease;
}
.insights-carousel__dot:hover { background: rgba(201,162,39,0.55); }
.insights-carousel__dot.is-active {
  background: var(--gold);
  transform: scale(1.3);
  box-shadow: 0 0 6px rgba(201,162,39,0.6);
}

/* ---------- Favourite attribute card ---------- */
.fav-attr {
  display: grid;
  grid-template-columns: minmax(150px, 38%) 1fr;
  gap: 1.2rem;
  align-items: center;
}
@media (max-width: 520px) {
  .fav-attr { grid-template-columns: 1fr; }
}
.fav-attr__hero {
  text-align: center;
  padding: .9rem .4rem;
  background:
    radial-gradient(ellipse at 50% 0%, rgba(201,162,39,0.15) 0%, transparent 70%),
    rgba(0,0,0,0.25);
  border: 1px solid var(--border-dim);
  border-radius: var(--radius);
}
.fav-attr__pct {
  font-family: 'Cinzel', serif;
  font-size: 2.6rem;
  color: var(--gold-light);
  line-height: 1;
  text-shadow: 0 0 18px rgba(201,162,39,0.35);
}
.fav-attr__pct span {
  font-size: 1.2rem; color: var(--text-muted);
}
.fav-attr__name {
  font-family: 'Cinzel', serif;
  color: var(--gold);
  font-size: 1.15rem;
  letter-spacing: .05em;
  margin-top: .3rem;
}
.fav-attr__sub {
  font-family: 'Crimson Text', serif;
  font-style: italic;
  font-size: .85rem;
  color: var(--text-muted);
  margin-top: .35rem;
}
.fav-attr__breakdown {
  list-style: none;
  margin: 0; padding: 0;
  display: grid; gap: .3rem;
}
.fav-attr__row {
  display: grid;
  grid-template-columns: 6rem 1fr 1.8rem;
  align-items: center;
  gap: .55rem;
  font-family: 'Crimson Text', serif;
  font-size: .9rem;
  color: var(--text-muted);
}
.fav-attr__row.is-top { color: var(--text); }
.fav-attr__row-label {
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.fav-attr__row-track {
  background: rgba(255,255,255,0.04);
  border-radius: 999px;
  height: 8px;
  overflow: hidden;
}
.fav-attr__row-fill {
  height: 100%;
  background: linear-gradient(90deg, #8a6e1c, var(--gold));
  border-radius: 999px;
  width: 0;
  animation: barchart-grow 1s ease-out forwards;
}
.fav-attr__row.is-top .fav-attr__row-fill {
  background: linear-gradient(90deg, var(--gold), #f5d76e);
  box-shadow: 0 0 8px rgba(201,162,39,.4);
}
.fav-attr__row-count {
  text-align: right;
  font-variant-numeric: tabular-nums;
  color: var(--gold-light);
  font-size: .9rem;
}

/* ---------- Totals grid ---------- */
.totals-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(115px, 1fr));
  gap: .6rem;
}
.totals-cell {
  background: rgba(0,0,0,0.22);
  border: 1px solid var(--border-dim);
  border-radius: var(--radius);
  padding: .85rem .4rem;
  text-align: center;
  transition: border-color .18s ease, transform .18s ease;
}
.totals-cell:hover {
  border-color: rgba(201,162,39,0.35);
  transform: translateY(-1px);
}
.totals-cell__value {
  font-family: 'Cinzel', serif;
  color: var(--gold-light);
  font-size: 1.55rem;
  line-height: 1;
  text-shadow: 0 0 10px rgba(201,162,39,0.18);
}
.totals-cell__label {
  margin-top: .3rem;
  font-family: 'Crimson Text', serif;
  font-size: .78rem;
  color: var(--text-muted);
  letter-spacing: .02em;
}

/* ---------- Combat panel ---------- */
.combat-stats {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(120px, 1fr));
  gap: .8rem;
}
.combat-stat {
  text-align: center;
  padding: .8rem .5rem;
  background: rgba(0,0,0,0.25);
  border: 1px solid var(--border-dim);
  border-radius: var(--radius);
}
.combat-stat__value {
  font-family: 'Cinzel', serif;
  font-size: 1.5rem;
  color: var(--gold-light);
  line-height: 1.1;
}
.combat-stat__label {
  font-family: 'Crimson Text', serif;
  font-size: .8rem;
  color: var(--text-muted);
  margin-top: .25rem;
}
.combat-outcome-bar {
  display: flex;
  height: 18px;
  border-radius: 999px;
  overflow: hidden;
  margin-top: 1rem;
  border: 1px solid var(--border-dim);
}
.combat-outcome-bar__seg {
  display: flex; align-items: center; justify-content: center;
  font-size: .72rem;
  color: #0a0810;
  font-family: 'Cinzel', serif;
  letter-spacing: .03em;
  white-space: nowrap;
  overflow: hidden;
}
.combat-outcome-bar__seg--win     { background: #6fbf73; }
.combat-outcome-bar__seg--loss    { background: #c05050; }
.combat-outcome-bar__seg--neutral { background: #8a8a8a; }

/* ---------- Empty state ---------- */
.empty-state {
  text-align: center;
  padding: 1rem .5rem;
  color: var(--text-muted);
  font-family: 'Crimson Text', serif;
  font-style: italic;
}

/* ---------- Footer note ---------- */
.stats-note {
  margin-top: 2rem;
  text-align: center;
  color: var(--text-muted);
  font-family: 'Crimson Text', serif;
  font-size: .9rem;
  font-style: italic;
}
.stats-note a { color: var(--gold); }
