/* ════════════════════════════════════════════════════════════════════
   SymposiON — subject-panel.css
   Subject panel + tile grid for the browse / subject pages
   ════════════════════════════════════════════════════════════════════ */

/* ─── Per-subject accent tints via data-subject ─────────────────────
   Uses --sp-accent for the border, banner bg, and CTA glow.
   Falls back to terra for unknown subjects.
──────────────────────────────────────────────────────────────────── */
[data-subject]                { --sp-accent: var(--sym-terra,  #D97B5C); }
[data-subject="odyssey"]      { --sp-accent: var(--sym-terra,  #D97B5C); }
[data-subject="iliad"]        { --sp-accent: var(--sym-gold,   #C4A448); }
[data-subject="grammar"]      { --sp-accent: var(--sym-sage,   #6A8752); }
[data-subject="ancient-greek"]{ --sp-accent: var(--sym-gold,   #C4A448); }
[data-subject="latin"]        { --sp-accent: var(--sym-gold,   #C4A448); }
[data-subject="history"]      { --sp-accent: var(--sym-sage,   #6A8752); }
[data-subject="literature"]   { --sp-accent: var(--sym-sage,   #6A8752); }
[data-subject="modern-greek"] { --sp-accent: var(--sym-sage,   #6A8752); }
[data-subject="tragedy"]      { --sp-accent: var(--sym-terra,  #D97B5C); }


/* ─── Subject tabs ───────────────────────────────────────────────── */
.subject-tabs {
  display: flex;
  gap: 2px;
  flex-wrap: wrap;
  margin-bottom: 20px;
  border-bottom: 1px solid rgba(255,255,255,0.07);
  padding-bottom: 2px;
}
.subject-tab {
  font-family: var(--sym-font-sans, 'Inter', sans-serif);
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 1.4px;
  text-transform: uppercase;
  padding: 9px 18px;
  background: none;
  border: none;
  color: var(--sym-fg-muted, #867660);
  cursor: pointer;
  border-bottom: 2px solid transparent;
  margin-bottom: -1px;
  transition: color .18s, border-color .18s;
}
.subject-tab:hover { color: var(--sym-fg, #F0EBE0); }
.subject-tab.active {
  color: var(--sym-terra, #D97B5C);
  border-bottom-color: var(--sym-terra, #D97B5C);
}

/* Auto-advance progress bar under the active tab */
.subject-tab.active::after {
  content: '';
  display: block;
  position: absolute;
  bottom: -2px;
  left: 0;
  height: 2px;
  width: 0%;
  background: var(--sym-terra, #D97B5C);
  opacity: 0.45;
}
.subject-tab {
  position: relative; /* needed for ::after positioning */
}
/* Running animation — added by JS when auto-rotate is active */
.subject-tab.active.is-auto-running::after {
  animation: tabProgress var(--tab-duration, 6.5s) linear forwards;
}
@keyframes tabProgress {
  from { width: 0%; }
  to   { width: 100%; }
}


/* ─── Panel layout ───────────────────────────────────────────────── */
.subject-panel {
  display: grid;
  grid-template-columns: 260px 1fr;
  gap: 0;
  border: 1px solid color-mix(in srgb, var(--sp-accent) 18%, transparent);
  margin-bottom: 24px;
  background: var(--sym-bg-card, #1A130C);
  overflow: hidden;
  position: relative;
}
@media (max-width: 768px) {
  .subject-panel { grid-template-columns: 1fr; }
}


/* ─── Left side ──────────────────────────────────────────────────── */
.subject-side {
  position: relative;
  padding: 32px 28px 28px;
  border-right: 1px solid color-mix(in srgb, var(--sp-accent) 14%, transparent);
  display: flex;
  flex-direction: column;
  gap: 6px;
  overflow: hidden;
}

.subject-roman {
  font-family: var(--sym-font-serif, 'Cormorant Garamond', serif);
  font-size: 11px;
  font-weight: 400;
  letter-spacing: 3px;
  text-transform: uppercase;
  color: var(--sp-accent);
  opacity: 0.7;
  margin-bottom: 4px;
}

.subject-title {
  font-family: var(--sym-font-serif, 'Cormorant Garamond', serif);
  font-size: 28px;
  font-weight: 600;
  letter-spacing: -0.3px;
  color: var(--sym-fg, #F0EBE0);
  margin: 0;
  line-height: 1.15;
}

.subject-sub {
  font-family: var(--sym-font-mono, monospace);
  font-size: 10px;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--sym-fg-muted, #867660);
  margin: 2px 0 6px;
}

.subject-summary {
  font-size: 12.5px;
  line-height: 1.65;
  color: rgba(240,235,224,0.62);
  margin: 0;
  flex: 1;
}

/* Faint background ornament illustration */
.subject-ornament {
  position: absolute;
  right: -30px;
  bottom: -20px;
  width: 180px;
  height: 180px;
  color: var(--sp-accent);
  opacity: 0.07;
  pointer-events: none;
}
.subject-ornament svg { width: 100%; height: 100%; }

/* Small foreground icon */
.subject-icon {
  width: 40px;
  height: 40px;
  color: var(--sp-accent);
  margin-top: 8px;
}
.subject-icon svg { width: 100%; height: 100%; }

.subject-meta {
  display: flex;
  align-items: center;
  gap: 6px;
  font-family: var(--sym-font-mono, monospace);
  font-size: 10px;
  letter-spacing: 1.2px;
  text-transform: uppercase;
  color: var(--sym-fg-muted, #867660);
  margin-top: 12px;
}
.subject-meta .dot { opacity: 0.4; }
.subject-meta .levels { color: var(--sp-accent); opacity: 0.8; }


/* ─── Right side — tiles ─────────────────────────────────────────── */
.subject-tiles-wrap {
  display: flex;
  flex-direction: column;
  padding: 20px 20px 20px 24px;
  gap: 16px;
}

.subject-tiles-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.subject-tagline {
  font-family: var(--sym-font-mono, monospace);
  font-size: 9.5px;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--sym-fg-muted, #867660);
}

.subject-all-link {
  font-family: var(--sym-font-sans, 'Inter', sans-serif);
  font-size: 10.5px;
  letter-spacing: 0.8px;
  color: var(--sp-accent);
  background: none;
  border: none;
  cursor: pointer;
  padding: 0;
  transition: opacity .18s;
}
.subject-all-link:hover { opacity: 0.72; }

.subject-tiles {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
  gap: 10px;
}


/* ─── Game tile ──────────────────────────────────────────────────── */
.tile {
  display: flex;
  flex-direction: column;
  background: var(--sym-bg-dark, #0D0A06);
  border: 1px solid color-mix(in srgb, var(--sp-accent) 15%, transparent);
  text-decoration: none;
  color: inherit;
  transition: border-color .2s, transform .2s, box-shadow .2s;
  cursor: pointer;
}
.tile:hover {
  border-color: color-mix(in srgb, var(--sp-accent) 45%, transparent);
  transform: translateY(-2px);
  box-shadow: 0 6px 20px rgba(0,0,0,0.3);
}

.tile-banner {
  height: 72px;
  background: color-mix(in srgb, var(--sp-accent) 8%, var(--sym-bg-dark, #0D0A06));
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  color: var(--sp-accent);
}
.tile-banner svg {
  width: 52px;
  height: 52px;
  opacity: 0.75;
}

.tile-body {
  padding: 12px 14px;
  display: flex;
  flex-direction: column;
  gap: 4px;
  flex: 1;
}

.tile-title {
  font-family: var(--sym-font-serif, 'Cormorant Garamond', serif);
  font-size: 15px;
  font-weight: 600;
  letter-spacing: -0.1px;
  color: var(--sym-fg, #F0EBE0);
  margin: 0;
  line-height: 1.25;
}

.tile-meta {
  font-size: 10.5px;
  color: var(--sym-fg-muted, #867660);
  margin: 0;
  line-height: 1.4;
}

.tile-cta {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-top: auto;
  padding-top: 10px;
  font-family: var(--sym-font-mono, monospace);
  font-size: 9.5px;
  letter-spacing: 1.2px;
  text-transform: uppercase;
  color: var(--sp-accent);
}


/* ═══════════════════════════════════════════════════════════════════
   PANEL TAB GROUPS — animated carousel between grade tabs
   ═══════════════════════════════════════════════════════════════════ */
.panels-tab-group {
  display: none;
  animation: panelFadeIn 0.28s ease;
}
.panels-tab-group.active {
  display: block;
}
@keyframes panelFadeIn {
  from { opacity: 0; transform: translateY(10px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* ─── Global subject accents (grade page panels + wherever data-subject appears) ─── */
[data-subject="verbs"]       { --sp-accent: var(--sym-terra,  #D97B5C); }
[data-subject="tragedy"]     { --sp-accent: var(--sym-terra,  #D97B5C); }
[data-subject="literature"]  { --sp-accent: var(--sym-sage,   #6A8752); }
[data-subject="modern-greek"]{ --sp-accent: var(--sym-sage,   #6A8752); }

/* ─── Home-page tab overrides (scoped so they don't bleed into grade panels) ─── */
.panels-tab-group[data-tab="gym-a"] [data-subject="odyssey"] { --sp-accent: var(--sym-terra, #D97B5C); }
.panels-tab-group[data-tab="gym-c"] [data-subject="eleni"]   { --sp-accent: var(--sym-terra, #D97B5C); }
.panels-tab-group[data-tab="gram"]  [data-subject="verbs"]   { --sp-accent: var(--sym-terra, #D97B5C); }
.panels-tab-group[data-tab="gram"]  [data-subject="latin"]   { --sp-accent: var(--sym-gold,  #C4A448); }


/* ═══════════════════════════════════════════════════════════════════
   GRADE PAGE — subject-card restyled to match tile aesthetic
   ═══════════════════════════════════════════════════════════════════ */
.subject-card {
  background: var(--sym-bg-dark, #0D0A06) !important;
  border: 1px solid rgba(240,235,224,0.1) !important;
  border-radius: 0 !important;
  overflow: hidden;
  cursor: pointer;
  transition: border-color .2s, transform .2s, box-shadow .2s;
  display: flex;
  flex-direction: column;
}
.subject-card:hover {
  border-color: rgba(217,123,92,0.45) !important;
  transform: translateY(-2px);
  box-shadow: 0 6px 20px rgba(0,0,0,.35);
}
.subject-card .card-banner {
  height: 80px !important;
  font-size: 32px !important;
  display: flex;
  align-items: center;
  justify-content: center;
}
.subject-card .subj-body {
  padding: 14px 16px 12px !important;
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.subject-card h3 {
  font-family: var(--sym-font-serif, 'Cormorant Garamond', serif) !important;
  font-size: 16px !important;
  font-weight: 600 !important;
  letter-spacing: -0.1px;
  color: var(--sym-fg, #F0EBE0) !important;
  margin: 0 !important;
}
.subject-card .subj-desc {
  font-size: 11px !important;
  color: var(--sym-fg-muted, #867660) !important;
  line-height: 1.5 !important;
}
.subject-card .subj-footer {
  margin-top: auto;
  padding-top: 10px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-family: var(--sym-font-mono, monospace);
  font-size: 9.5px;
  letter-spacing: 1.2px;
  text-transform: uppercase;
  color: var(--sym-terra, #D97B5C);
}
.subject-card .card-arrow { color: var(--sym-terra, #D97B5C); }

/* Track section header on grade page */
.track-section .grid-label {
  font-family: var(--sym-font-mono, monospace) !important;
  font-size: 10px !important;
  letter-spacing: 2.5px !important;
  text-transform: uppercase !important;
  color: var(--sym-fg-muted, #867660) !important;
  padding: 20px 0 10px !important;
  border-bottom: 1px solid rgba(255,255,255,0.06) !important;
  margin-bottom: 14px !important;
}


/* ═══════════════════════════════════════════════════════════════════
   SUBJECT PAGE — g-card restyled to match tile aesthetic
   ═══════════════════════════════════════════════════════════════════ */
.g-card {
  background: var(--sym-bg-dark, #0D0A06) !important;
  border: 1px solid rgba(240,235,224,0.09) !important;
  border-radius: 0 !important;
  cursor: pointer;
  transition: border-color .2s, transform .2s, box-shadow .2s;
  overflow: hidden;
}
.g-card:hover {
  border-color: rgba(217,123,92,0.4) !important;
  transform: translateY(-2px);
  box-shadow: 0 6px 20px rgba(0,0,0,.35);
}
.g-card .g-banner {
  height: 80px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  font-size: 32px !important;
  position: relative;
}
.g-card .g-body {
  padding: 12px 14px 10px !important;
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.g-card h3 {
  font-family: var(--sym-font-serif, 'Cormorant Garamond', serif) !important;
  font-size: 15px !important;
  font-weight: 600 !important;
  letter-spacing: -0.1px;
  margin: 0 0 2px !important;
}
.g-card .g-desc {
  font-size: 10.5px !important;
  color: var(--sym-fg-muted, #867660) !important;
  line-height: 1.45 !important;
}
.g-card .g-meta {
  margin-top: 10px;
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.g-card .meta-tags { display: flex; gap: 6px; flex-wrap: wrap; }
.g-card .tag {
  font-family: var(--sym-font-mono, monospace) !important;
  font-size: 9px !important;
  letter-spacing: 1px !important;
  text-transform: uppercase !important;
  color: var(--sym-fg-muted, #867660) !important;
  border: 1px solid rgba(255,255,255,0.1) !important;
  padding: 2px 7px !important;
  background: none !important;
  border-radius: 0 !important;
}
.g-card .play-btn {
  font-family: var(--sym-font-mono, monospace);
  font-size: 11px;
  color: var(--sym-terra, #D97B5C);
  letter-spacing: 1px;
}
/* Free / Multi badges */
.g-card .free-b, .g-card .multi-b, .g-card .lock-b {
  position: absolute !important;
  top: 8px !important;
  right: 8px !important;
  font-family: var(--sym-font-mono, monospace) !important;
  font-size: 8.5px !important;
  letter-spacing: 1px !important;
  text-transform: uppercase !important;
  padding: 3px 7px !important;
  background: rgba(0,0,0,0.55) !important;
  border: 1px solid rgba(255,255,255,0.12) !important;
  color: var(--sym-sage, #6A8752) !important;
  border-radius: 0 !important;
}
.g-card .lock-b { color: rgba(255,255,255,0.45) !important; }

/* Subject hero on subject page — tighter */
.subject-hero {
  padding: 28px 24px 22px !important;
  min-height: unset !important;
}
.subject-hero h1 {
  font-family: var(--sym-font-serif, 'Cormorant Garamond', serif) !important;
  font-size: 32px !important;
  font-weight: 600 !important;
  margin: 6px 0 4px !important;
}
.subject-hero .grade-pill {
  font-family: var(--sym-font-mono, monospace) !important;
  font-size: 9.5px !important;
  letter-spacing: 2px !important;
  text-transform: uppercase !important;
  background: rgba(0,0,0,0.3) !important;
  border: 1px solid rgba(255,255,255,0.12) !important;
  padding: 4px 10px !important;
  border-radius: 0 !important;
  display: inline-block;
}
.subject-hero .filter-tabs { margin-top: 14px !important; }
.subject-hero .ftab {
  font-family: var(--sym-font-mono, monospace) !important;
  font-size: 9.5px !important;
  letter-spacing: 1.5px !important;
  text-transform: uppercase !important;
}
.games-content .grid-label {
  font-family: var(--sym-font-mono, monospace) !important;
  font-size: 10px !important;
  letter-spacing: 2px !important;
  text-transform: uppercase !important;
  color: var(--sym-fg-muted, #867660) !important;
  padding: 20px 24px 10px !important;
}
.games-grid {
  padding: 0 24px 24px !important;
  gap: 10px !important;
}


/* ═══════════════════════════════════════════════════════════════════
   BROWSE PAGE — browse-box restyled to match tile aesthetic
   ═══════════════════════════════════════════════════════════════════ */
.browse-box {
  background: var(--sym-bg-dark, #0D0A06) !important;
  border: 1px solid rgba(240,235,224,0.09) !important;
  border-radius: 0 !important;
  transition: border-color .2s, transform .2s, box-shadow .2s;
  overflow: hidden;
}
.browse-box:not(.disabled):hover {
  border-color: rgba(217,123,92,0.4) !important;
  transform: translateY(-2px);
  box-shadow: 0 6px 20px rgba(0,0,0,.35);
}
.browse-box .browse-box-banner {
  height: 80px !important;
  font-size: 32px !important;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 0 !important;
}
.browse-box .browse-box-body h3 {
  font-family: var(--sym-font-serif, 'Cormorant Garamond', serif) !important;
  font-size: 16px !important;
  font-weight: 600 !important;
  color: var(--sym-fg, #F0EBE0) !important;
}
.browse-box .browse-box-body p {
  font-size: 11px !important;
  color: var(--sym-fg-muted, #867660) !important;
}


/* ═══════════════════════════════════════════════════════════════════
   GRADE PAGE — panel layout spacing
   ═══════════════════════════════════════════════════════════════════ */
.grade-subjects-wrap--panels { padding: 0 0 60px; }
.grade-subjects-wrap--panels .subject-panel { margin-bottom: 18px; }

/* Track label (Γενική Παιδεία / Θεωρητική Κατεύθυνση) */
.grade-track-label {
  font-family: var(--sym-font-mono, 'JetBrains Mono', monospace);
  font-size: 11px;
  letter-spacing: 2.4px;
  text-transform: uppercase;
  color: var(--sym-stone, #867660);
  margin: 28px 0 10px;
}
.grade-track-label:first-child { margin-top: 0; }

/* Featured tile gets a subtle accent edge */
.tile[data-featured] {
  border-color: color-mix(in srgb, var(--sp-accent) 40%, transparent);
  box-shadow:   0 0 0 1px color-mix(in srgb, var(--sp-accent) 18%, transparent);
}


/* ─── "Όλα τα παιχνίδια" overflow tile ──────────────────────────── */
.tile--all-games {
  border-style: dashed;
  border-color: color-mix(in srgb, var(--sp-accent) 28%, transparent);
  background: transparent;
}
.tile--all-games:hover {
  border-color: color-mix(in srgb, var(--sp-accent) 55%, transparent);
  background: color-mix(in srgb, var(--sp-accent) 5%, transparent);
  transform: translateY(-2px);
  box-shadow: 0 6px 20px rgba(0,0,0,0.25);
}

/* Banner: shows the +N count instead of an illustration */
.tile--all-games .tile-banner--count {
  height: 72px;
  background: transparent;
  border-bottom: 1px dashed color-mix(in srgb, var(--sp-accent) 20%, transparent);
  display: flex;
  align-items: center;
  justify-content: center;
}

.tile-overflow-count {
  font-family: var(--sym-font-serif, 'Cormorant Garamond', serif);
  font-size: 40px;
  font-weight: 600;
  line-height: 1;
  color: var(--sp-accent);
  opacity: 0.80;
  letter-spacing: -1px;
}

/* Title inherits accent so it reads as a CTA, not a game name */
.tile--all-games .tile-title {
  color: var(--sp-accent);
  font-size: 13.5px;
  letter-spacing: 0.1px;
}
