/* ────────────────────────────────────────────────────────────────────────
   annales-cards.css — Design system partagé pour les tuiles des annales
   Utilisé par :
     - _source/modules/annales/index.html           (sujets obligatoires)
     - _source/modules/vocabulaire/annales/index.html (épreuve anglais)
   ──────────────────────────────────────────────────────────────────────── */

/* ── Grille années ─────────────────────────────────────────────────────── */
.annales-year-grid { margin: 0 0 2rem }
@media (max-width: 820px) { .annales-year-grid { grid-template-columns: repeat(3, 1fr) !important } }
@media (max-width: 600px) { .annales-year-grid { grid-template-columns: repeat(2, 1fr) !important } }
@media (max-width: 400px) { .annales-year-grid { grid-template-columns: 1fr !important } }

/* ── Boutons de carte annales ──────────────────────────────────────────── */
.annales-card-links { display: flex; flex-direction: column; gap: 0.5rem; margin-top: 0.5rem }

.annales-btn {
  display: flex; align-items: center; gap: 0.75rem;
  padding: 0.7rem 1rem; text-decoration: none;
  font-family: var(--font-heading, 'Outfit', sans-serif);
  font-weight: 700; font-size: 0.85rem; letter-spacing: 0.03em;
  color: var(--color-text); transition: opacity 0.15s;
}
.annales-btn:hover { opacity: .8 }

.annales-btn--quiz  { background: var(--color-primary); color: var(--color-secondary); border-left: none }
.annales-btn--corrige { background: var(--overlay-accent-08); border-left: 4px solid var(--color-accent) }

.annales-btn-icon {
  display: inline-flex; align-items: center; justify-content: center;
  width: 1.5rem; height: 1.5rem; font-size: 0.75rem; line-height: 1;
  flex-shrink: 0; color: var(--color-secondary);
}
.annales-btn--quiz .annales-btn-icon    { background: transparent; color: inherit }
.annales-btn--corrige .annales-btn-icon { background: var(--color-accent) }

/* ── Halo tuile (cohérent design system) ──────────────────────────────── */
.theme-grid .theme-card:hover {
  border-color: var(--color-accent-red);
  box-shadow: 0 0 0 6px var(--overlay-danger-glow-28),
              0 0 30px 12px var(--overlay-danger-glow-18),
              0 16px 32px var(--overlay-danger-glow-16);
  transform: translateY(-2px);
  transition: box-shadow .2s ease, border-color .2s ease, transform .2s ease;
}

/* ── Tuile verrouillée (sessions à venir) ─────────────────────────────── */
.theme-card--locked { opacity: .55; cursor: default; position: relative; pointer-events: none }
.theme-card--locked:hover { border-color: var(--color-border) !important; box-shadow: none !important }
.annales-lock-icon { position: absolute; top: 0.6rem; right: 0.6rem; display: flex; opacity: .6 }
.annales-lock-msg {
  font-size: 0.8rem; color: var(--color-text-muted); margin-top: 0.5rem;
  font-family: var(--font-heading, 'Outfit', sans-serif);
  font-weight: 700; letter-spacing: 0.02em; line-height: 1.4;
}
.annales-lock-sub {
  font-family: var(--font-body, 'Lexend', sans-serif);
  font-weight: 400; font-size: 0.72rem; font-style: italic;
  color: var(--color-text-muted); letter-spacing: 0;
}

/* ── Score line compact ───────────────────────────────────────────────── */
.annales-score-line {
  display: flex; align-items: center; gap: 0.5rem;
  padding: 0.45rem 0.75rem; border-left: 4px solid;
  font-family: var(--font-heading, 'Outfit', sans-serif);
  font-size: 0.78rem; font-weight: 700; letter-spacing: 0.02em;
}
.annales-score-line--pass { border-left-color: var(--color-accent); background: var(--overlay-accent-08); color: var(--color-accent) }
.annales-score-line--fail { border-left-color: var(--color-accent-red); background: var(--overlay-danger-07); color: var(--color-accent-red) }

/* ── Dashboard progression ────────────────────────────────────────────── */
.annales-status-none {
  display: flex; align-items: center; gap: 0.5rem;
  padding: 0.45rem 0.75rem; margin-top: 0.5rem;
  border-left: 4px solid var(--color-border);
  background: var(--overlay-primary-05);
  font-family: var(--font-body, 'Lexend', sans-serif);
  font-size: 0.78rem; color: var(--color-text-muted); letter-spacing: 0.02em;
}
.annales-resume-btn {
  display: flex; align-items: center; gap: 0.75rem;
  padding: 0.7rem 1rem; background: var(--color-accent);
  color: var(--color-secondary); border-left: none; text-decoration: none;
  font-family: var(--font-heading, 'Outfit', sans-serif);
  font-weight: 700; font-size: 0.85rem; letter-spacing: 0.03em; transition: opacity 0.15s;
}
.annales-resume-btn:hover { opacity: .8 }
.annales-resume-icon {
  display: inline-flex; align-items: center; justify-content: center;
  width: 1.5rem; height: 1.5rem; background: transparent;
  color: inherit; font-size: 0.75rem; line-height: 1; flex-shrink: 0;
}

.annales-kpi-reset {
  display: inline-flex; align-items: center; margin-top: 0.5rem;
  padding: 0.2rem 0.55rem; font-size: 0.68rem;
  font-family: var(--font-heading, 'Outfit', sans-serif);
  font-weight: 700; color: var(--color-text-muted);
  background: none; border: 1px solid var(--color-border);
  cursor: pointer; letter-spacing: 0.05em; text-transform: uppercase;
}
.annales-kpi-reset:hover { color: var(--color-accent-red); border-color: var(--color-accent-red) }

/* ── Accordéon résultats ──────────────────────────────────────────────── */
.annales-accordion { margin-top: 0 }
.annales-accordion-toggle {
  display: flex; align-items: center; justify-content: space-between;
  width: 100%; padding: 0.55rem 0.75rem; border: none; border-left: 4px solid;
  cursor: pointer; text-align: left;
  font-family: var(--font-heading, 'Outfit', sans-serif);
  font-size: 0.82rem; font-weight: 700; color: var(--color-text);
  letter-spacing: 0.02em; transition: opacity 0.15s;
}
.annales-accordion-toggle:hover { opacity: .85 }
.annales-accordion-toggle--pass { border-left-color: var(--color-accent); background: var(--overlay-accent-08) }
.annales-accordion-toggle--fail { border-left-color: var(--color-accent-red); background: var(--overlay-danger-07) }

.annales-toggle-left  { display: flex; align-items: baseline; gap: 0.5rem; min-width: 0; flex: 1 }
.annales-toggle-score { font-size: 0.92rem; font-weight: 800; letter-spacing: 0.01em; flex-shrink: 0 }
.annales-toggle-score--pass { color: var(--color-accent) }
.annales-toggle-score--fail { color: var(--color-accent-red) }
.annales-toggle-meta {
  font-size: 0.72rem; color: var(--color-text-muted); font-weight: 400;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.annales-accordion-arrow {
  font-size: 0.55rem; transition: transform 0.18s; flex-shrink: 0;
  margin-left: 0.4rem; color: var(--color-text-muted);
}
.annales-accordion.open .annales-accordion-arrow { transform: rotate(180deg) }

.annales-accordion-content { display: none; border-left: 4px solid; padding: 0.65rem 0.75rem }
.annales-accordion-content--pass { border-left-color: var(--color-accent);     background: var(--color-secondary) }
.annales-accordion-content--fail { border-left-color: var(--color-accent-red); background: var(--color-secondary) }
.annales-accordion.open .annales-accordion-content { display: block }

.annales-section-sep { border: none; border-top: 1px solid var(--color-border-light); margin: 0.45rem 0 }

/* ── Grille tuiles dans l'accordéon ──────────────────────────────────── */
.annales-tile-grid {
  display: grid; grid-template-columns: 1fr 1fr;
  gap: 0.4rem; margin-bottom: 0.45rem; overflow: hidden;
}
.annales-tile {
  padding: 0.45rem 0.55rem; display: flex; flex-direction: row;
  align-items: baseline; gap: 0.35rem; flex-wrap: wrap;
  transition: background 0.15s, box-shadow 0.15s;
  min-width: 0; word-break: break-word; overflow: hidden;
}
.annales-tile:hover { box-shadow: 0 0 0 2px var(--color-primary), 0 2px 8px var(--overlay-primary-08) }
.annales-tile--kpi     { background: var(--overlay-primary-05); border-left: 3px solid var(--color-primary) }
.annales-tile--pass    { background: var(--overlay-accent-08);  border-left: 3px solid var(--color-accent) }
.annales-tile--fail    { background: var(--overlay-danger-07);  border-left: 3px solid var(--color-accent-red) }
.annales-tile--neutral { background: var(--overlay-primary-05); border-left: 3px solid var(--color-border) }

.annales-tile-lbl {
  font-size: 0.58rem; font-family: var(--font-heading, 'Outfit', sans-serif);
  font-weight: 700; letter-spacing: 0.07em; text-transform: uppercase;
  color: var(--color-text-muted);
}
.annales-tile-val  { font-family: var(--font-heading, 'Outfit', sans-serif); font-size: 0.72rem; font-weight: 800; color: var(--color-text) }
.annales-tile-sub  { font-size: 0.68rem; color: var(--color-text-muted); font-weight: 400; margin-top: 0.08rem; flex-basis: 100% }
.annales-tile-bar  { height: 3px; width: 100%; background: var(--overlay-black-10); margin-top: 0.25rem; overflow: hidden; flex-basis: 100% }
.annales-tile-fill--pass { height: 100%; background: var(--color-accent);     transition: width 0.4s ease; min-width: 2px }
.annales-tile-fill--fail { height: 100%; background: var(--color-accent-red); transition: width 0.4s ease; min-width: 2px }
@media (max-width: 400px) { .annales-tile-grid { grid-template-columns: 1fr } }

/* ── Pied de carte ────────────────────────────────────────────────────── */
.annales-corrige-ok {
  display: flex; align-items: center; gap: 0.3rem;
  font-size: 0.75rem; font-weight: 600; color: var(--color-accent); margin-bottom: 0.25rem;
}
.annales-card-footer {
  display: flex; justify-content: flex-end;
  padding-top: 0.35rem; margin-top: 0.25rem;
  border-top: 1px solid var(--color-border-light);
}
.annales-reset-btn {
  font-size: 0.7rem; font-family: var(--font-body, 'Lexend', sans-serif);
  color: var(--color-text-muted); background: none; border: none;
  cursor: pointer; padding: 0; letter-spacing: 0.02em;
}
.annales-reset-btn:hover { color: var(--color-accent-red) }

/* ── Modal confirmation ───────────────────────────────────────────────── */
.annales-modal-overlay {
  position: fixed; inset: 0; background: rgba(15, 20, 30, .65);
  display: flex; align-items: center; justify-content: center;
  z-index: 9999; padding: 1rem;
}
.annales-modal {
  background: var(--color-secondary); max-width: 440px; width: 100%;
  padding: 1.5rem; border-left: 4px solid var(--color-accent-red);
}
.annales-modal h4 {
  font-family: var(--font-heading, 'Outfit', sans-serif);
  font-size: 1rem; font-weight: 800; color: var(--color-accent-red);
  margin: 0 0 0.75rem; letter-spacing: 0.02em;
}
.annales-modal p { font-size: 0.85rem; color: var(--color-text); margin: 0 0 1.25rem; line-height: 1.55 }
.annales-modal-actions { display: flex; gap: 0.75rem; flex-wrap: wrap }
.annales-modal-confirm {
  display: inline-flex; align-items: center; padding: 0.6rem 1.1rem;
  background: var(--color-accent); color: var(--color-secondary);
  text-decoration: none; font-family: var(--font-heading, 'Outfit', sans-serif);
  font-weight: 700; font-size: 0.82rem; letter-spacing: 0.03em;
  border: none; cursor: pointer;
}
.annales-modal-cancel {
  display: inline-flex; align-items: center; padding: 0.6rem 1.1rem;
  background: none; color: var(--color-text); border: 1px solid var(--color-border);
  font-family: var(--font-heading, 'Outfit', sans-serif);
  font-weight: 700; font-size: 0.82rem; cursor: pointer; letter-spacing: 0.03em;
}

/* ── Dark mode ────────────────────────────────────────────────────────── */
html[data-theme='dark'] .annales-btn--quiz        { background: var(--color-primary); color: var(--color-secondary) }
html[data-theme='dark'] .annales-btn--corrige     { background: var(--dm-teal-10) }
html[data-theme='dark'] .annales-btn              { color: var(--dm-text) }
html[data-theme='dark'] .annales-resume-btn       { background: var(--color-accent); color: var(--color-secondary) }

html[data-theme='dark'] .annales-accordion-toggle--pass    { background: var(--dm-teal-10) }
html[data-theme='dark'] .annales-accordion-toggle--fail    { background: var(--dm-danger-12) }
html[data-theme='dark'] .annales-accordion-toggle          { color: var(--dm-text) }
html[data-theme='dark'] .annales-accordion-content--pass   { background: var(--dm-card) }
html[data-theme='dark'] .annales-accordion-content--fail   { background: var(--dm-card) }

html[data-theme='dark'] .annales-stats-grid        { border-color: var(--dm-border) }
html[data-theme='dark'] .annales-stats-cell        { border-right-color: var(--dm-border) }
html[data-theme='dark'] .annales-stats-lbl         { color: var(--dm-text-muted) }
html[data-theme='dark'] .annales-stats-val         { color: var(--dm-text) }
html[data-theme='dark'] .annales-section-sep       { border-top-color: var(--dm-border) }
html[data-theme='dark'] .annales-weak-item         { background: var(--dm-danger-12) }
html[data-theme='dark'] .annales-weak-bar          { background: var(--dm-border) }
html[data-theme='dark'] .annales-status-none       { background: var(--dm-slate-5); border-left-color: var(--dm-border); color: var(--dm-text-muted) }
html[data-theme='dark'] .annales-card-footer       { border-top-color: var(--dm-border) }

html[data-theme='dark'] .annales-tile--kpi     { background: var(--dm-slate-5) }
html[data-theme='dark'] .annales-tile--neutral { background: var(--dm-slate-5) }
html[data-theme='dark'] .annales-tile--pass    { background: var(--dm-teal-10) }
html[data-theme='dark'] .annales-tile--fail    { background: var(--dm-danger-12) }
html[data-theme='dark'] .annales-tile-lbl      { color: var(--dm-text-muted) }
html[data-theme='dark'] .annales-tile-val      { color: var(--dm-text) }
html[data-theme='dark'] .annales-tile-sub      { color: var(--dm-text-muted) }

html[data-theme='dark'] .theme-grid .theme-card:hover {
  box-shadow: 0 0 0 6px var(--dm-green-28), 0 0 30px 12px var(--dm-green-18), 0 16px 32px var(--dm-green-12);
}

html[data-theme='dark'] .annales-modal          { background: var(--dm-surface) }
html[data-theme='dark'] .annales-modal p        { color: var(--dm-text) }
html[data-theme='dark'] .annales-modal-cancel   { color: var(--dm-text); border-color: var(--dm-border) }
