/* ============================================================================
   Elite Stats Display — v7 FINAL
   Location: static/core/css/elite-stats.css

   Strategy: CSS Grid with data-count on the wrapper drives column count.
   Alignment driven by data-align on wrapper (group) or individual .elite-stat.

   - 1 item  → 1 col centred, max 480px
   - 2 items → 2 cols centred
   - 3 items → 3 cols
   - 4+ items → 4 cols, wraps to next row
   - Mobile: 2 cols → 1 col, nothing clips
   - Alignment: center / left / right at group or per-card level
============================================================================ */


/* ==========================================================================
   ACCENT COLOUR MAP
   'brand' inherits --elite-yellow from ThemeSettings via base.html
========================================================================== */
[data-accent="brand"],
[data-accent=""]       { --stat-color: var(--elite-yellow, #F2BC3A); }
[data-accent="yellow"]   { --stat-color: #F2BC3A; }
[data-accent="blue"]   { --stat-color: #4A9EFF; }
[data-accent="green"]  { --stat-color: #34C77B; }
[data-accent="red"]    { --stat-color: #FF5F5F; }
[data-accent="purple"] { --stat-color: var(--elite-purple, #A78BFA); }
[data-accent="orange"] { --stat-color: #FF8A3D; }
[data-accent="white"]  { --stat-color: #FFFFFF; }


/* ==========================================================================
   SCHEDULE FONT SIZE MAP
   Driven by data-schedule-title-size and data-schedule-row-size on .elite-stats
========================================================================== */
[data-schedule-title-size="sm"]  .elite-stat__schedule-title { font-size: 0.875rem; }
[data-schedule-title-size="md"]  .elite-stat__schedule-title { font-size: 1rem; }
[data-schedule-title-size="lg"]  .elite-stat__schedule-title { font-size: 1.125rem; }
[data-schedule-title-size="xl"]  .elite-stat__schedule-title { font-size: 1.25rem; }
[data-schedule-title-size="2xl"] .elite-stat__schedule-title { font-size: 1.375rem; }

[data-schedule-row-size="sm"]  .elite-stat__schedule-day,
[data-schedule-row-size="sm"]  .elite-stat__schedule-time  { font-size: 0.75rem; }
[data-schedule-row-size="md"]  .elite-stat__schedule-day,
[data-schedule-row-size="md"]  .elite-stat__schedule-time  { font-size: 0.8125rem; }
[data-schedule-row-size="lg"]  .elite-stat__schedule-day,
[data-schedule-row-size="lg"]  .elite-stat__schedule-time  { font-size: 0.9375rem; }
[data-schedule-row-size="xl"]  .elite-stat__schedule-day,
[data-schedule-row-size="xl"]  .elite-stat__schedule-time  { font-size: 1rem; }
[data-schedule-row-size="2xl"] .elite-stat__schedule-day,
[data-schedule-row-size="2xl"] .elite-stat__schedule-time  { font-size: 1.125rem; }


/* ==========================================================================
   GRID WRAPPER
   data-count sets exact column count — no guessing, no orphaned gaps.
========================================================================== */
.elite-stats {
  display: grid;
  gap: clamp(0.875rem, 2vw, 1.375rem);
  width: 100%;
  padding: 0;
  grid-template-columns: repeat(auto-fit, minmax(min(100%, 220px), 1fr));
  align-items: stretch;
}

.elite-stats[data-count="1"] { grid-template-columns: minmax(0, 480px); justify-content: center; }
.elite-stats[data-count="2"] { grid-template-columns: repeat(2, 1fr); max-width: 720px; margin: 0 auto; }
.elite-stats[data-count="3"] { grid-template-columns: repeat(3, 1fr); }
.elite-stats[data-count="4"] { grid-template-columns: repeat(4, 1fr); }
.elite-stats[data-count="5"],
.elite-stats[data-count="6"],
.elite-stats[data-count="7"],
.elite-stats[data-count="8"] { grid-template-columns: repeat(4, 1fr); }


/* ==========================================================================
   CONTENT ALIGNMENT
   Group level: data-align on .elite-stats sets default for all cards.
   Card level:  data-align on .elite-stat overrides just that one card.
========================================================================== */

/* ── Group-level ─────────────────────────────────────────── */
.elite-stats[data-align="center"] .elite-stat         { align-items: center; text-align: center; }
.elite-stats[data-align="left"]   .elite-stat         { align-items: flex-start; text-align: left; }
.elite-stats[data-align="right"]  .elite-stat         { align-items: flex-end; text-align: right; }

.elite-stats[data-align="center"] .elite-stat__content { align-items: center; }
.elite-stats[data-align="left"]   .elite-stat__content { align-items: flex-start; }
.elite-stats[data-align="right"]  .elite-stat__content { align-items: flex-end; }

/* ── Per-card overrides ──────────────────────────────────── */
.elite-stat[data-align="center"]                       { align-items: center; text-align: center; }
.elite-stat[data-align="left"]                         { align-items: flex-start; text-align: left; }
.elite-stat[data-align="right"]                        { align-items: flex-end; text-align: right; }

.elite-stat[data-align="center"] .elite-stat__content  { align-items: center; }
.elite-stat[data-align="left"]   .elite-stat__content  { align-items: flex-start; }
.elite-stat[data-align="right"]  .elite-stat__content  { align-items: flex-end; }

/* ── Schedule alignment ──────────────────────────────────────
   Rows (day/time pairs) always stay left-internally so the
   day label and time value don't float apart in the middle.
   Only the title and note text-align changes.
   Right alignment flips the row direction with row-reverse.
──────────────────────────────────────────────────────────── */

/* Base: schedule block always left-aligned */
.elite-stat__schedule { text-align: left; }

/* Group center */
.elite-stats[data-align="center"] .elite-stat__schedule        { text-align: left; }
.elite-stats[data-align="center"] .elite-stat__schedule-title  { text-align: center; }
.elite-stats[data-align="center"] .elite-stat__schedule-note   { text-align: center; }

/* Group left (explicit, same as default) */
.elite-stats[data-align="left"] .elite-stat__schedule          { text-align: left; }
.elite-stats[data-align="left"] .elite-stat__schedule-title    { text-align: left; }
.elite-stats[data-align="left"] .elite-stat__schedule-note     { text-align: left; }

/* Group right */
.elite-stats[data-align="right"] .elite-stat__schedule         { text-align: right; }
.elite-stats[data-align="right"] .elite-stat__schedule-title   { text-align: right; }
.elite-stats[data-align="right"] .elite-stat__schedule-row     { flex-direction: row-reverse; }
.elite-stats[data-align="right"] .elite-stat__schedule-note    { text-align: right; }

/* Per-card center */
.elite-stat[data-align="center"] .elite-stat__schedule         { text-align: left; }
.elite-stat[data-align="center"] .elite-stat__schedule-title   { text-align: center; }
.elite-stat[data-align="center"] .elite-stat__schedule-note    { text-align: center; }

/* Per-card left */
.elite-stat[data-align="left"]   .elite-stat__schedule         { text-align: left; }
.elite-stat[data-align="left"]   .elite-stat__schedule-title   { text-align: left; }
.elite-stat[data-align="left"]   .elite-stat__schedule-note    { text-align: left; }

/* Per-card right */
.elite-stat[data-align="right"]  .elite-stat__schedule         { text-align: right; }
.elite-stat[data-align="right"]  .elite-stat__schedule-title   { text-align: right; }
.elite-stat[data-align="right"]  .elite-stat__schedule-row     { flex-direction: row-reverse; }
.elite-stat[data-align="right"]  .elite-stat__schedule-note    { text-align: right; }

/* Compact: alignment locked — row layout depends on flex-start */
.elite-stats--compact .elite-stat                              { align-items: flex-start !important; text-align: left !important; }
.elite-stats--compact .elite-stat__content                     { align-items: center !important; }


/* ==========================================================================
   BASE STAT CARD
========================================================================== */
.elite-stat {
  display: flex;
  flex-direction: column;
  align-items: center;   /* default: centre — overridden by data-align */
  text-align: center;
  gap: 0.5rem;
  position: relative;
  box-sizing: border-box;
  width: 100%;
  min-width: 0;
  overflow: hidden;

  transition:
    transform 0.28s var(--elite-ease, cubic-bezier(0.4,0,0.2,1)),
    box-shadow 0.28s var(--elite-ease, cubic-bezier(0.4,0,0.2,1)),
    background 0.28s var(--elite-ease, cubic-bezier(0.4,0,0.2,1)),
    border-color 0.28s var(--elite-ease, cubic-bezier(0.4,0,0.2,1));
}

.elite-stat__icon {
  font-size: 1.5rem;
  line-height: 1;
  flex-shrink: 0;
  transition: transform 0.3s cubic-bezier(0.34,1.56,0.64,1);
}
.elite-stat:hover .elite-stat__icon { transform: scale(1.15); }

.elite-stat__content {
  display: flex;
  flex-direction: column;
  align-items: center;   /* default: overridden by data-align */
  gap: 0.3rem;
  width: 100%;
  min-width: 0;
  flex: 1;
}

.elite-stat__number {
  font-size: clamp(1.5rem, 3vw, 2.25rem);
  font-weight: 800;
  line-height: 1.1;
  color: var(--stat-color, var(--elite-yellow, #F2BC3A));
  letter-spacing: -0.02em;
  word-break: break-word;
  overflow-wrap: break-word;
  max-width: 100%;
  font-variant-numeric: tabular-nums;
}

.elite-stat__label {
  font-size: clamp(0.68rem, 1.3vw, 0.8rem);
  font-weight: 700;
  color: rgba(255,255,255,0.75);
  text-transform: uppercase;
  letter-spacing: 0.07em;
  line-height: 1.35;
  word-break: break-word;
  max-width: 100%;
}


/* ==========================================================================
   STYLE 1 — HERO  (glassmorphism, for dark hero backgrounds)
   --card-overlay and --card-blur set via inline style on the wrapper.
========================================================================== */
.elite-stats--hero .elite-stat {
  padding: clamp(1rem, 2vw, 1.6rem) clamp(0.875rem, 1.75vw, 1.375rem);
  background: rgba(255, 255, 255, var(--card-overlay, 0.08));
  border: 1px solid rgba(255, 255, 255, calc(var(--card-overlay, 0.08) + 0.05));
  border-radius: 14px;
  backdrop-filter: blur(var(--card-blur, 0px));
  -webkit-backdrop-filter: blur(var(--card-blur, 0px));
}

/* Coloured top-bar reveal on hover */
.elite-stats--hero .elite-stat::before {
  content: "";
  position: absolute;
  inset: 0 0 auto 0;
  height: 3px;
  background: var(--stat-color, var(--elite-yellow, #F2BC3A));
  transform: scaleX(0);
  transform-origin: left;
  transition: transform 0.38s var(--elite-ease, cubic-bezier(0.4,0,0.2,1));
  border-radius: 14px 14px 0 0;
}
.elite-stats--hero .elite-stat:hover::before { transform: scaleX(1); }

.elite-stats--hero .elite-stat:hover {
  background: rgba(255, 255, 255, calc(var(--card-overlay, 0.08) + 0.04));
  border-color: rgba(242, 188, 58, 0.35);
  transform: translateY(-5px);
  box-shadow: 0 16px 40px rgba(0,0,0,0.22), 0 0 0 1px rgba(242,188,58,0.25);
}

.elite-stats--hero .elite-stat__number {
  font-size: clamp(1.5rem, 2.8vw, 2.25rem);
  color: var(--stat-color, var(--elite-yellow, #F2BC3A));
}
.elite-stats--hero .elite-stat[data-type="text"] .elite-stat__number,
.elite-stats--hero .elite-stat[data-type="time"] .elite-stat__number {
  font-size: clamp(1rem, 1.8vw, 1.4rem);
  font-weight: 700;
  line-height: 1.3;
  letter-spacing: 0;
}
.elite-stats--hero .elite-stat__label {
  font-size: clamp(0.65rem, 1.1vw, 0.76rem);
  color: rgba(255,255,255,0.72);
  letter-spacing: 0.07em;
}
.elite-stats--hero .elite-stat__icon {
  font-size: 1.7rem;
  color: rgba(255,255,255,0.72);
  margin-bottom: 0.15rem;
}


/* ==========================================================================
   STYLE 2 — CARDS  (light elevated, for light section backgrounds)
========================================================================== */
.elite-stats--cards .elite-stat {
  background: #fff;
  padding: clamp(1.25rem, 2vw, 1.75rem) clamp(1rem, 1.6vw, 1.375rem);
  border-radius: 12px;
  border: 1px solid #e9ecef;
  box-shadow: 0 2px 8px rgba(0,0,0,0.06);
}
.elite-stats--cards .elite-stat:hover {
  transform: translateY(-6px);
  box-shadow: 0 12px 28px rgba(0,0,0,0.1);
  border-color: var(--stat-color, var(--elite-yellow, #F2BC3A));
}
.elite-stats--cards .elite-stat__number {
  font-size: clamp(1.5rem, 2.6vw, 2rem);
  color: var(--stat-color, var(--elite-yellow, #F2BC3A));
}
.elite-stats--cards .elite-stat[data-type="text"] .elite-stat__number,
.elite-stats--cards .elite-stat[data-type="time"] .elite-stat__number {
  font-size: clamp(0.95rem, 1.5vw, 1.15rem);
  font-weight: 700;
  line-height: 1.4;
  letter-spacing: 0;
}
.elite-stats--cards .elite-stat__label {
  color: #6c757d;
  font-size: clamp(0.68rem, 1.1vw, 0.8rem);
  text-transform: none;
  letter-spacing: 0.01em;
  font-weight: 600;
}
.elite-stats--cards .elite-stat__icon {
  font-size: 1.75rem;
  color: var(--stat-color, var(--elite-yellow, #F2BC3A));
  margin-bottom: 0.4rem;
}
/* Cards on light bg — label colour override */
.elite-stats--cards .elite-stat__label { color: #6c757d; }


/* ==========================================================================
   STYLE 3 — COMPACT  (left-bordered rows, always stacked vertically)
========================================================================== */
.elite-stats--compact {
  grid-template-columns: 1fr !important;
  max-width: 100% !important;
  gap: 0.625rem;
}
.elite-stats--compact .elite-stat {
  flex-direction: row;
  align-items: flex-start;
  text-align: left;
  padding: 0.875rem 1.125rem;
  background: #f8f9fa;
  border-radius: 8px;
  border-left: 3px solid var(--stat-color, var(--elite-yellow, #F2BC3A));
  border-top: none;
  border-right: none;
  border-bottom: none;
  gap: 0.75rem;
  overflow: visible;
}
.elite-stats--compact .elite-stat:hover {
  background: #f1f3f5;
  transform: translateX(3px);
  box-shadow: 0 2px 10px rgba(0,0,0,0.06);
}
.elite-stats--compact .elite-stat__icon {
  font-size: 1.2rem;
  color: var(--stat-color, var(--elite-yellow, #F2BC3A));
  flex-shrink: 0;
  margin-top: 0.1rem;
}
.elite-stats--compact .elite-stat__content {
  flex-direction: row;
  align-items: center;
  justify-content: space-between;
  gap: 0.875rem;
}
.elite-stats--compact .elite-stat__label {
  color: #343a40;
  font-size: 0.8125rem;
  text-transform: none;
  letter-spacing: 0;
  font-weight: 600;
  flex: 0 0 auto;
}
.elite-stats--compact .elite-stat__number {
  font-size: 1rem;
  color: var(--stat-color, var(--elite-yellow, #F2BC3A));
  font-weight: 700;
  text-align: right;
  flex: 1 1 auto;
  min-width: 0;
  word-break: break-word;
}
.elite-stats--compact .elite-stat[data-type="text"] .elite-stat__number,
.elite-stats--compact .elite-stat[data-type="time"] .elite-stat__number {
  font-size: 0.875rem;
  font-weight: 600;
  line-height: 1.3;
}


/* ==========================================================================
   SCHEDULE BLOCK — shared across all styles
   lg values are the base; overridden by data-schedule-*-size selectors above.
========================================================================== */
.elite-stat__schedule {
  display: flex;
  flex-direction: column;
  gap: 0;
  width: 100%;
  min-width: 0;
  text-align: left;   /* base: always left; overridden by alignment rules above */
  flex: 1;
}

/* Section heading: "Office Hours" / "Yard Hours" */
.elite-stat__schedule-title {
  font-size: 1.125rem;
  font-weight: 800;
  color: var(--stat-color, var(--elite-yellow, #F2BC3A));
  text-transform: uppercase;
  letter-spacing: 0.08em;
  padding-bottom: 0.4rem;
  margin-bottom: 0.375rem;
  border-bottom: 1px solid rgba(255,255,255,0.15);
  line-height: 1.2;
  word-break: break-word;
}
.elite-stats--cards   .elite-stat__schedule-title { border-bottom-color: #e9ecef; }
.elite-stats--compact .elite-stat__schedule-title { border-bottom-color: #dee2e6; }

/* Day / time row */
.elite-stat__schedule-row {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: 0.5rem;
  padding: 0.28rem 0;
  border-bottom: 1px solid rgba(255,255,255,0.06);
  min-width: 0;
}
.elite-stat__schedule-row:last-of-type { border-bottom: none; }
.elite-stats--cards   .elite-stat__schedule-row { border-bottom-color: #f1f3f5; }
.elite-stats--compact .elite-stat__schedule-row { border-bottom-color: #f1f3f5; }

/* Day label */
.elite-stat__schedule-day {
  font-size: 0.9375rem;
  font-weight: 600;
  color: rgba(255,255,255,0.92);
  flex-shrink: 1;
  min-width: 0;
  word-break: break-word;
}
.elite-stats--cards   .elite-stat__schedule-day,
.elite-stats--compact .elite-stat__schedule-day { color: #212529; }

/* Time value */
.elite-stat__schedule-time {
  font-size: 0.9375rem;
  font-weight: 500;
  color: rgba(255,255,255,0.72);
  text-align: right;
  flex-shrink: 0;
  white-space: nowrap;
  font-variant-numeric: tabular-nums;
}
.elite-stats--cards   .elite-stat__schedule-time,
.elite-stats--compact .elite-stat__schedule-time { color: #6c757d; }

/* Footnote / GMT note */
.elite-stat__schedule-note {
  font-size: 0.7rem;
  color: rgba(255,255,255,0.48);
  font-style: italic;
  line-height: 1.5;
  margin: 0.5rem 0 0;
  padding-top: 0.4rem;
  border-top: 1px solid rgba(255,255,255,0.09);
  word-break: break-word;
}
.elite-stats--cards   .elite-stat__schedule-note { color: #adb5bd; border-top-color: #e9ecef; }
.elite-stats--compact .elite-stat__schedule-note { color: #adb5bd; border-top-color: #dee2e6; }

/* Breathing room for label below a schedule block */
.elite-stat[data-type="schedule"] .elite-stat__label { margin-top: 0.5rem; }


/* ==========================================================================
   COUNTER ANIMATION
========================================================================== */
.elite-stat__number.counting {
  animation: elite-pulse 0.35s cubic-bezier(0.34,1.56,0.64,1);
}
@keyframes elite-pulse {
  0%, 100% { transform: scale(1); }
  50%       { transform: scale(1.04); }
}


/* ==========================================================================
   ENTRANCE ANIMATION
   JS adds .elite-stats--animated once wrapper scrolls into view.
   Each card has style="--i: N" for stagger delay.
========================================================================== */
.elite-stats--animated .elite-stat {
  animation: elite-fadein 0.55s var(--elite-ease, cubic-bezier(0.4,0,0.2,1)) both;
  animation-delay: calc(var(--i, 0) * 75ms);
}
@keyframes elite-fadein {
  from { opacity: 0; transform: translateY(12px); }
  to   { opacity: 1; transform: translateY(0); }
}


/* ==========================================================================
   RESPONSIVE BREAKPOINTS
========================================================================== */

/* ── Tablet: max 3 columns ─────────────────────────────── */
@media (max-width: 1024px) {
  .elite-stats[data-count="4"],
  .elite-stats[data-count="5"],
  .elite-stats[data-count="6"],
  .elite-stats[data-count="7"],
  .elite-stats[data-count="8"] {
    grid-template-columns: repeat(3, 1fr);
  }
  .elite-stats[data-count="2"] { max-width: 580px; }
}

/* ── Small tablet / large phone: max 2 columns ─────────── */
@media (max-width: 700px) {
  .elite-stats[data-count="1"] {
    grid-template-columns: 1fr;
    max-width: 100%;
  }
  .elite-stats[data-count="2"],
  .elite-stats[data-count="3"],
  .elite-stats[data-count="4"],
  .elite-stats[data-count="5"],
  .elite-stats[data-count="6"],
  .elite-stats[data-count="7"],
  .elite-stats[data-count="8"] {
    grid-template-columns: repeat(2, 1fr);
    max-width: 100%;
    margin: 0;
  }

  .elite-stats--hero .elite-stat {
    padding: 0.875rem 0.75rem;
  }
  .elite-stats--hero .elite-stat__number {
    font-size: clamp(1.25rem, 5.5vw, 1.75rem);
  }
  .elite-stats--hero .elite-stat__label {
    font-size: clamp(0.6rem, 2.2vw, 0.72rem);
    letter-spacing: 0.04em;
  }
  .elite-stats--hero .elite-stat__icon {
    font-size: 1.375rem;
  }

  /* Schedule rows on narrow cards: let time wrap below day */
  .elite-stat__schedule-row {
    flex-wrap: wrap;
    gap: 0.125rem 0.5rem;
  }
  .elite-stat__schedule-time {
    text-align: left;
    white-space: normal;
    flex-shrink: 1;
  }
}

/* ── Phone: single column ───────────────────────────────── */
@media (max-width: 440px) {
  .elite-stats[data-count="2"],
  .elite-stats[data-count="3"],
  .elite-stats[data-count="4"],
  .elite-stats[data-count="5"],
  .elite-stats[data-count="6"],
  .elite-stats[data-count="7"],
  .elite-stats[data-count="8"] {
    grid-template-columns: 1fr;
  }
  .elite-stats--hero .elite-stat { padding: 0.875rem 1rem; }
}

/* ── Compact: gap tweak on mobile ───────────────────────── */
@media (max-width: 700px) {
  .elite-stats--compact { gap: 0.5rem; }
}


/* ==========================================================================
   PRINT
========================================================================== */
@media print {
  .elite-stats {
    grid-template-columns: repeat(4, 1fr) !important;
    gap: 0.75rem !important;
  }
  .elite-stat {
    background: white !important;
    border: 1px solid #dee2e6 !important;
    box-shadow: none !important;
    transform: none !important;
    backdrop-filter: none !important;
    -webkit-backdrop-filter: none !important;
    padding: 0.75rem !important;
  }
  .elite-stat__number        { color: #000 !important; }
  .elite-stat__label         { color: #555 !important; }
  .elite-stat__schedule-day,
  .elite-stat__schedule-time { color: #333 !important; }
  .elite-stat__schedule-note { color: #888 !important; }
}