/* ==========================================================================
   ITL Archive — Shared styles + per-skin colour overrides
   Used by both archive-master.php (.itl-arc-page--master)
   and  archive-licence.php  (.itl-arc-page--licence).
   All components use the unified .itl-arc-* BEM namespace.
   ========================================================================== */

/* ══════════════════════════════════════════════════════════════════════════
   HERO
══════════════════════════════════════════════════════════════════════════ */
.itl-arc-hero {
  padding: 72px 0 56px;
  position: relative;
  overflow: hidden;
}

.itl-arc-hero::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, transparent, #e8b422, transparent);
}

.itl-arc-hero__inner {
  max-width: 1380px; margin: 0 auto;
  padding: 0 clamp(16px, 4vw, 80px);
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 40px;
  align-items: center;
}

.itl-arc-hero__content { display: flex; flex-direction: column; gap: 16px; }

.itl-arc-hero__eyebrow {
  font-size: 11px; font-weight: 700;
  letter-spacing: .14em; text-transform: uppercase;
  color: #e8b422; margin: 0;
}

.itl-arc-hero__title {
  margin: 0;
  font-size: clamp(28px, 4.5vw, 50px);
  font-weight: 800; color: #fff; line-height: 1.06;
}

.itl-arc-hero__desc {
  margin: 0;
  font-size: 15px; 
  color: rgba(255,255,255,.72);
  line-height: 1.65; 
  max-width: 900px;
}

.itl-arc-hero__cta {
  display: inline-flex; align-items: center; gap: 8px;
  background: #e8b422; color: #0b1630;
  font-size: 14px; font-weight: 700;
  padding: 13px 24px; border-radius: 8px;
  text-decoration: none; align-self: flex-start;
  transition: background .15s, transform .15s;
}
.itl-arc-hero__cta:hover { background: #f5c833; transform: translateY(-1px); }

.itl-arc-hero__stats   { display: flex; flex-direction: column; gap: 12px; flex-shrink: 0; }
.itl-arc-hero__stat    {
  background: rgba(255,255,255,.08); border: 1px solid rgba(255,255,255,.14);
  border-radius: 12px; padding: 16px 20px; text-align: center; min-width: 120px;
}
.itl-arc-hero__stat-val { display: block; font-size: 26px; font-weight: 800; color: #e8b422; line-height: 1; }
.itl-arc-hero__stat-lbl { display: block; font-size: 11px; color: rgba(255,255,255,.55); margin-top: 4px; font-weight: 600; }

/* ══════════════════════════════════════════════════════════════════════════
   INTRO SECTION
══════════════════════════════════════════════════════════════════════════ */
.itl-arc-intro {
  background: #fff; border-bottom: 1px solid #e8ecf2; padding: 56px 0;
}

.itl-arc-intro__inner {
  max-width: 1380px; margin: 0 auto;
  padding: 0 clamp(16px, 4vw, 80px);
  display: grid; grid-template-columns: 1fr 1fr;
  gap: 56px; align-items: center;
}

.itl-arc-intro__heading {
  margin: 0 0 14px;
  font-size: clamp(20px, 2.8vw, 32px);
  font-weight: 800; color: #0b1630; line-height: 1.15;
}
.itl-arc-intro__text {
  margin: 0 0 14px;
  font-size: 14.5px; color: #374163; line-height: 1.7;
}
.itl-arc-intro__text:last-child { margin-bottom: 0; }

.itl-arc-intro__pills { display: flex; flex-wrap: wrap; gap: 8px; }
.itl-arc-intro__pill {
  display: flex; align-items: center; gap: 6px;
  font-size: 12px; font-weight: 600; padding: 6px 14px;
  border-radius: 100px; background: #fff;
  border: 1px solid #e2e6f0; color: #374163;
}
.itl-arc-intro__pill--gold {
  background: rgba(232,180,34,.1);
  border-color: rgba(232,180,34,.3); color: #7a4800;
}

.itl-arc-intro__highlight {
  background: #fff; border: 1px solid #e8ecf2; border-radius: 16px;
  padding: 28px 28px 24px;
  display: flex; flex-direction: column; gap: 16px;
}
.itl-arc-intro__highlight-title {
  font-size: 12px; font-weight: 700;
  letter-spacing: .1em; text-transform: uppercase;
  color: #9aa3bb; margin: 0;
}

.itl-arc-intro__feature      { display: flex; align-items: flex-start; gap: 12px; }
.itl-arc-intro__feature-icon {
  width: 36px; height: 36px; border-radius: 8px;
  display: flex; align-items: center; justify-content: center;
  font-size: 16px; flex-shrink: 0;
  /* skin sets background colour */
}
.itl-arc-intro__feature-name   { font-size: 13px; font-weight: 700; color: #0b1630; margin: 0 0 2px; }
.itl-arc-intro__feature-detail { font-size: 12px; color: #6b7494; margin: 0; }

/* ══════════════════════════════════════════════════════════════════════════
   LISTING LAYOUT
══════════════════════════════════════════════════════════════════════════ */
.itl-arc-section-head {
  max-width: 1380px; margin: 0 auto;
  padding: 32px clamp(16px, 4vw, 40px) 0;
}
.itl-arc-section-head__title { font-size: 22px; font-weight: 800; color: #0b1630; margin: 0 0 4px; }
.itl-arc-section-head__sub   { font-size: 13px; color: #6b7494; margin: 0; }

.itl-arc-body {
  max-width: 1380px; margin: 0 auto;
  padding: 24px clamp(16px, 4vw, 40px) 40px;
  display: grid; grid-template-columns: 240px 1fr;
  gap: 24px; align-items: start;
}

/* ── Sidebar ──────────────────────────────────────────────────────────────── */
.itl-arc-sidebar { position: sticky; top: 24px; display: flex; flex-direction: column; gap: 14px; }

.itl-arc-sidebar__box  { background: #fff; border: 1px solid #e8ecf2; border-radius: 12px; overflow: hidden; }
.itl-arc-sidebar__head {
  padding: 12px 16px;
  font-size: 10px; font-weight: 700; letter-spacing: .12em; text-transform: uppercase;
  color: rgba(255,255,255,.55);
  /* skin sets background colour */
}

.itl-arc-sidebar__search      { padding: 12px 14px; }
.itl-arc-sidebar__search-wrap { position: relative; }
.itl-arc-sidebar__search input {
  width: 100%; border: 1.5px solid #e2e6f0; border-radius: 8px;
  padding: 8px 12px 8px 34px; font-size: 13px; color: #0b1630; box-sizing: border-box;
}
.itl-arc-sidebar__search input:focus {
  outline: none; border-color: #e8b422; box-shadow: 0 0 0 3px rgba(232,180,34,.12);
}
.itl-arc-sidebar__search-icon {
  position: absolute; left: 10px; top: 50%; transform: translateY(-50%);
  color: #9aa3bb; pointer-events: none;
}

.itl-arc-filter-list { padding: 8px 0; }
.itl-arc-filter-item {
  display: flex; align-items: center; justify-content: space-between;
  padding: 8px 16px; font-size: 13px; color: #374163;
  text-decoration: none; min-height: 40px;
  transition: background .12s;
}
.itl-arc-filter-item:hover  { background: #f8f9fc; color: #0b1630; }
.itl-arc-filter-item.active {
  background: rgba(232,180,34,.1); color: #7a4800; font-weight: 700;
}

.itl-arc-filter-count {
  font-size: 11px; background: #f0f2f7; color: #9aa3bb;
  padding: 1px 7px; border-radius: 100px; font-weight: 600;
}
.itl-arc-filter-item.active .itl-arc-filter-count {
  background: rgba(232,180,34,.2); color: #7a4800;
}

.itl-arc-sidebar__stats {
  padding: 12px 16px; border-top: 1px solid #f0f2f7;
  display: flex; flex-direction: column; gap: 7px;
}
.itl-arc-stat-row { display: flex; justify-content: space-between; font-size: 12px; margin: 0; }
.itl-arc-stat-row dt { color: #9aa3bb; font-weight: normal; }
.itl-arc-stat-row dd { font-weight: 600; color: #0b1630; margin: 0; }

.itl-arc-sidebar__cta-btn {
  display: block; text-align: center; background: #25d366; color: #fff;
  font-weight: 700; font-size: 13px; padding: 10px; border-radius: 8px;
  text-decoration: none; margin: 12px 14px 14px;
}

/* ── Top bar ──────────────────────────────────────────────────────────────── */
.itl-arc-topbar {
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: 18px; flex-wrap: wrap; gap: 8px;
}
.itl-arc-topbar__count        { font-size: 13px; color: #6b7494; }
.itl-arc-topbar__count strong { color: #0b1630; font-size: 16px; margin-right: 4px; }
.itl-arc-topbar__reset        { font-size: 12px; color: #9aa3bb; text-decoration: none; }
.itl-arc-topbar__reset:hover  { color: #0b1630; }

/* ── Cards grid ───────────────────────────────────────────────────────────── */
.itl-arc-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap: 16px; }

.itl-arc-card {
  background: #fff; border: 1px solid #e8ecf2; border-radius: 14px; overflow: hidden;
  display: flex; flex-direction: column;
  text-decoration: none; color: inherit;
  transition: transform .18s, box-shadow .18s, border-color .18s;
}
.itl-arc-card:hover {
  transform: translateY(-3px);
  box-shadow: 0 10px 32px rgba(0,0,0,.09);
  border-color: transparent;
}

.itl-arc-card__stripe  { height: 4px; }
.itl-arc-card__body    { padding: 18px 18px 12px; flex: 1; display: flex; flex-direction: column; gap: 8px; }
.itl-arc-card__top     { display: flex; align-items: flex-start; justify-content: space-between; justify-content: flex-end;}
.itl-arc-card__emoji   { font-size: 30px; line-height: 1; }
.itl-arc-card__title   { display: flex;
        gap: 8px;
        align-items: center;
        margin: 0; font-size: 15px; font-weight: 700; color: #0b1630; line-height: 1.3; }
.itl-arc-card__excerpt { margin: 0; font-size: 12px; color: #6b7494; line-height: 1.55; }

.itl-arc-card__tags { padding: 0 18px 12px; display: flex; flex-wrap: wrap; gap: 5px; }
.itl-arc-tag         { font-size: 11px; font-weight: 600; padding: 2px 8px; border-radius: 100px; background: #f0f2f7; color: #374163; white-space: nowrap; }
.itl-arc-tag--gold   { background: rgba(232,180,34,.12); color: #7a4800; }
.itl-arc-tag--green  { background: rgba(16,185,129,.1); color: #065f46; }

.itl-arc-card__footer {
  padding: 10px 18px; border-top: 1px solid #f4f5f8;
  display: flex; align-items: center; justify-content: flex-end;
}
.itl-arc-card__cta-txt { font-size: 12px; font-weight: 700; color: #0b1630; }
.itl-arc-card__niveau  { font-size: 10px; font-weight: 700; color: #fff; padding: 3px 9px; border-radius: 100px; /* skin sets background */ }

.itl-arc-empty { text-align: center; padding: 72px 0; color: #9aa3bb; }

/* ── Cross-sell banner ────────────────────────────────────────────────────── */
.itl-arc-xsell {
  display: flex; align-items: center; justify-content: space-between; gap: 16px;
  border-radius: 14px; padding: 20px 24px; margin-top: 32px; text-decoration: none;
  /* skin sets background gradient */
}
.itl-arc-xsell__left    { display: flex; flex-direction: column; gap: 4px; }
.itl-arc-xsell__eyebrow { font-size: 10px; font-weight: 700; letter-spacing: .12em; text-transform: uppercase; color: #e8b422; }
.itl-arc-xsell__title   { font-size: 17px; font-weight: 800; color: #fff; margin: 0; }
.itl-arc-xsell__sub     { font-size: 12px; color: rgba(255,255,255,.55); margin: 2px 0 0; }
.itl-arc-xsell__cta     {
  flex-shrink: 0; background: #e8b422; color: #0b1630;
  font-size: 13px; font-weight: 700; padding: 10px 20px;
  border-radius: 8px; white-space: nowrap;
}

/* ══════════════════════════════════════════════════════════════════════════
   WHY SECTION
══════════════════════════════════════════════════════════════════════════ */
.itl-arc-why { background: #fff; padding: 72px 0; border-top: 1px solid #e8ecf2; }
.itl-arc-why__inner  { max-width: 1380px; margin: 0 auto; padding: 0 clamp(16px, 4vw, 80px); }
.itl-arc-why__header { text-align: center; margin-bottom: 48px; }
.itl-arc-why__eyebrow {
  font-size: 11px; font-weight: 700; letter-spacing: .14em; text-transform: uppercase;
  color: #e8b422; margin: 0 0 10px;
}
.itl-arc-why__title { margin: 0; font-size: clamp(22px, 3vw, 36px); font-weight: 800; color: #0b1630; }
.itl-arc-why__grid  { display: grid; grid-template-columns: repeat(auto-fill, minmax(260px, 1fr)); gap: 16px; }

.itl-arc-why__item {
  display: flex; align-items: flex-start; gap: 14px; padding: 20px;
  background: #f8f9fb; border: 1px solid #edf0f7; border-radius: 12px;
  transition: border-color .15s, box-shadow .15s;
}
.itl-arc-why__item:hover { border-color: #e8b422; box-shadow: 0 4px 16px rgba(232,180,34,.1); }
.itl-arc-why__icon { font-size: 22px; line-height: 1; flex-shrink: 0; margin-top: 2px; }
.itl-arc-why__text { font-size: 13.5px; color: #374163; line-height: 1.55; font-weight: 500; margin: 0; }

/* ══════════════════════════════════════════════════════════════════════════
   CTA SECTION
══════════════════════════════════════════════════════════════════════════ */
.itl-arc-cta {
  padding: 72px 0; position: relative; overflow: hidden;
  /* skin sets background gradient */
}
.itl-arc-cta::before {
  content: ''; position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, transparent, #e8b422, transparent);
}
.itl-arc-cta__inner { max-width: 1180px; margin: 0 auto; padding: 0 clamp(16px, 4vw, 80px); text-align: center; }
.itl-arc-cta__title { margin: 0 0 12px; font-size: clamp(22px, 3.5vw, 38px); font-weight: 800; color: #fff; line-height: 1.1; }
.itl-arc-cta__sub   { margin: 0 0 36px; font-size: 15px; color: rgba(255,255,255,.68); line-height: 1.6; }
.itl-arc-cta__actions { display: flex; flex-wrap: wrap; justify-content: center; gap: 12px; }

.itl-arc-cta__btn {
  display: inline-flex; align-items: center; gap: 8px;
  font-size: 14px; font-weight: 700; padding: 13px 24px;
  border-radius: 8px; text-decoration: none;
  transition: transform .15s, opacity .15s;
}
.itl-arc-cta__btn--primary       { background: #e8b422; color: #0b1630; }
.itl-arc-cta__btn--primary:hover { background: #f5c833; transform: translateY(-1px); }
.itl-arc-cta__btn--outline       { background: transparent; color: #fff; border: 1.5px solid rgba(255,255,255,.35); }
.itl-arc-cta__btn--outline:hover { border-color: #fff; background: rgba(255,255,255,.07); transform: translateY(-1px); }

/* ══════════════════════════════════════════════════════════════════════════
   RESPONSIVE — Mobile-first
══════════════════════════════════════════════════════════════════════════ */
@media (max-width: 860px) {
  .itl-arc-hero__inner { grid-template-columns: 1fr; gap: 24px; padding: 48px clamp(16px, 4vw, 40px) 36px; }
  .itl-arc-hero__stats { flex-direction: row; flex-wrap: wrap; }
  .itl-arc-hero__stat  { min-width: unset; flex: 1; }

  .itl-arc-intro__inner { grid-template-columns: 1fr; gap: 32px; }

  .itl-arc-body { grid-template-columns: 1fr; padding: 20px clamp(12px, 3vw, 40px); }
  .itl-arc-sidebar { position: static; }

  .itl-arc-grid { grid-template-columns: 1fr 1fr; }
}

@media (max-width: 640px) {
  .itl-arc-hero { padding: 48px 0 36px; }
  .itl-arc-hero__cta   { width: 100%; justify-content: center; min-height: 50px; }
  .itl-arc-hero__stat  { padding: 12px 16px; }
  .itl-arc-hero__stat-val { font-size: 22px; }

  .itl-arc-filter-item { min-height: 44px; padding: 10px 16px; }
  .itl-arc-sidebar__search input { font-size: 16px; /* prevent iOS zoom */ }

  .itl-arc-grid { grid-template-columns: 1fr; }

  .itl-arc-cta { padding: 48px 0; }
  .itl-arc-cta__actions { flex-direction: column; align-items: stretch; }
  .itl-arc-cta__btn { justify-content: center; min-height: 50px; }

  .itl-arc-why { padding: 48px 0; }
  .itl-arc-why__grid { grid-template-columns: 1fr; }
}

@media (max-width: 520px) {
  .itl-arc-xsell { flex-direction: column; align-items: flex-start; }
  .itl-arc-xsell__cta { width: 100%; text-align: center; min-height: 48px; display: flex; align-items: center; justify-content: center; }
}

/* ==========================================================================
   ITL Archive — Masters Skin
   Accent: Purple #312e81
   Depends on: itlsys-archive-shared
   ========================================================================== */

/* Hero gradient */
.itl-arc-hero--master {
  background: linear-gradient(135deg, #0b1630 0%, #312e81 100%);
}

/* Sidebar head */
.itl-arc-hero--master ~ * .itl-arc-sidebar__head,
.itl-arc-page--master .itl-arc-sidebar__head {
  background: #312e81;
}

/* Feature icon */
.itl-arc-page--master .itl-arc-intro__feature-icon { background: #312e81; }

/* Purple intro pill */
.itl-arc-intro__pill--purple {
  background: rgba(49,46,129,.08);
  border-color: rgba(49,46,129,.2);
  color: #312e81;
}

/* Card niveau badge */
.itl-arc-page--master .itl-arc-card__niveau { background: #312e81; }

/* CTA section gradient */
.itl-arc-page--master .itl-arc-cta {
  background: linear-gradient(135deg, #0b1630 0%, #312e81 100%);
}

/* Cross-sell banner (pointing to Licences) */
.itl-arc-page--master .itl-arc-xsell {
  background: linear-gradient(135deg, #0b1630, #1e3a8a);
}

/* ==========================================================================
   ITL Archive — Licences Skin
   Accent: Navy #0b1630 / Blue #1e3a8a
   Depends on: itlsys-archive-shared
   ========================================================================== */

/* Hero gradient */
.itl-arc-hero--licence {
  background: linear-gradient(135deg, #0b1630 0%, #1e3a8a 100%);
}

/* Sidebar head */
.itl-arc-page--licence .itl-arc-sidebar__head {
  background: #0b1630;
  color: rgba(255,255,255,.5);
}

/* Feature icon */
.itl-arc-page--licence .itl-arc-intro__feature-icon { background: #0b1630; }

/* Card niveau badge */
.itl-arc-page--licence .itl-arc-card__niveau { background: #0b1630; }

/* CTA section gradient */
.itl-arc-page--licence .itl-arc-cta {
  background: linear-gradient(135deg, #0b1630 0%, #1e3a8a 100%);
}

/* Cross-sell banner (pointing to Masters) */
.itl-arc-page--licence .itl-arc-xsell {
  background: linear-gradient(135deg, #0b1630, #312e81);
}


/* ==========================================================================
   ITL Archive — Comprehensive mobile UX (May 2026 overhaul)
   Key pattern: vertical sidebar → horizontal scroll filter strip on mobile
   ========================================================================== */

/* ════════════════════ 860px — Tablet ════════════════════════════════════ */
@media (max-width: 860px) {

  /* Hero: stack */
  .itl-arc-hero { padding: 52px 0 40px; }
  .itl-arc-hero__inner { grid-template-columns: 1fr; gap: 24px; }
  .itl-arc-hero__stats { flex-direction: row; flex-wrap: wrap; gap: 8px; }
  .itl-arc-hero__stat  { min-width: unset; flex: 1 1 120px; }

  /* Intro: stack panels */
  .itl-arc-intro { padding: 40px 0; }
  .itl-arc-intro__inner { grid-template-columns: 1fr; gap: 28px; }

  /* Body: stack sidebar above main */
  .itl-arc-body {
    grid-template-columns: 1fr;
    padding: 0;
    gap: 0;
  }

  /* ── Sidebar → horizontal sticky filter strip ── */
  .itl-arc-sidebar {
    position: sticky;
    top: 0;
    z-index: 90;
    display: flex;
    flex-direction: row;
    align-items: center;
    gap: 0;
    background: #fff;
    border-bottom: 1px solid #e8ecf2;
    box-shadow: 0 2px 8px rgba(0,0,0,.05);
    overflow-x: auto;
    scrollbar-width: none;
    padding: 0 clamp(14px, 3vw, 28px);
  }
  .itl-arc-sidebar::-webkit-scrollbar { display: none; }

  /* Hide search box and info box on mobile */
  .itl-arc-sidebar__box--search   { display: none; }
  .itl-arc-sidebar__box--modalite .itl-arc-sidebar__stats  { display: none; }
  .itl-arc-sidebar__box--modalite .itl-arc-sidebar__cta-btn { display: none; }

  /* Both filter boxes: strip chrome, go inline */
  .itl-arc-sidebar__box--filters,
  .itl-arc-sidebar__box--modalite {
    display: flex;
    flex-direction: row;
    align-items: center;
    background: transparent;
    border: none;
    border-radius: 0;
    overflow: visible;
    flex-shrink: 0;
  }

  /* Separator between domaine & modalité pill groups */
  .itl-arc-sidebar__box--modalite::before {
    content: '';
    display: block;
    width: 1px;
    height: 24px;
    background: #e2e6f0;
    margin: 0 8px;
    flex-shrink: 0;
  }

  /* Filter list: horizontal flex of pills */
  .itl-arc-filter-list {
    display: flex;
    flex-direction: row;
    align-items: center;
    gap: 6px;
    padding: 10px 0;
  }

  /* Hide vertical sidebar heading */
  .itl-arc-sidebar__head { display: none; }

  /* Filter items: pill style */
  .itl-arc-filter-item {
    flex-shrink: 0;
    white-space: nowrap;
    border-radius: 100px;
    border: 1.5px solid #e2e6f0;
    font-size: 12.5px;
    font-weight: 600;
    padding: 6px 14px;
    min-height: 36px;
    background: #fff;
    color: #374163;
    justify-content: center;
    gap: 6px;
    transition: background .12s, border-color .12s, color .12s;
  }
  .itl-arc-filter-item:hover {
    background: #f4f6fb;
    border-color: #c8d0e0;
    color: #0b1630;
  }
  .itl-arc-filter-item.active {
    background: #0b1630;
    border-color: #0b1630;
    color: #fff;
  }
  .itl-arc-filter-item.active .itl-arc-filter-count {
    background: rgba(255,255,255,.2);
    color: rgba(255,255,255,.75);
  }
  .itl-arc-filter-count {
    font-size: 10px;
    padding: 1px 6px;
  }

  /* Main content: own padding */
  .itl-arc-body > main {
    padding: 20px clamp(14px, 3vw, 28px) 36px;
  }

  /* Card grid: 2-col on tablet */
  .itl-arc-grid { grid-template-columns: 1fr 1fr; }

  /* Section head */
  .itl-arc-section-head { padding: 24px clamp(14px, 3vw, 28px) 0; }
}

/* ════════════════════ 640px — Phone ════════════════════════════════════ */
@media (max-width: 640px) {

  /* Hero */
  .itl-arc-hero { padding: 40px 0 28px; }
  .itl-arc-hero__title { font-size: clamp(22px, 7vw, 30px); }
  .itl-arc-hero__desc  { font-size: 14px; }
  .itl-arc-hero__cta   {
    width: 100%; justify-content: center;
    padding: 14px 20px; min-height: 50px;
  }
  .itl-arc-hero__stats { gap: 6px; }
  .itl-arc-hero__stat  { padding: 12px 12px; flex: 1 1 calc(50% - 6px); }
  .itl-arc-hero__stat-val { font-size: 22px; }
  .itl-arc-hero__stat-lbl { font-size: 10.5px; }

  /* Intro */
  .itl-arc-intro { padding: 28px 0; }

  /* Filter pills: slightly smaller on phone */
  .itl-arc-filter-item { font-size: 12px; padding: 5px 12px; min-height: 34px; }
  .itl-arc-sidebar { padding: 0 14px; }

  /* Cards: single column */
  .itl-arc-grid { grid-template-columns: 1fr; gap: 10px; }

  .itl-arc-card__body    { padding: 14px 14px 10px; }
  .itl-arc-card__emoji   { font-size: 26px; }
  .itl-arc-card__title   { font-size: 14px; }
  .itl-arc-card__excerpt { font-size: 11.5px; }
  .itl-arc-card__tags    { padding: 0 14px 10px; }
  .itl-arc-card__footer  { padding: 8px 14px; }
  .itl-arc-card__cta-txt { font-size: 11.5px; }

  /* Topbar */
  .itl-arc-topbar { flex-wrap: wrap; gap: 6px; }
  .itl-arc-topbar__count strong { font-size: 15px; }

  /* Cross-sell banner: stack */
  .itl-arc-xsell {
    flex-direction: column;
    align-items: flex-start;
    gap: 14px;
    padding: 18px 16px;
  }
  .itl-arc-xsell__cta {
    width: 100%; text-align: center;
    padding: 12px 20px; min-height: 48px;
    display: flex; align-items: center; justify-content: center;
  }

  /* Why section */
  .itl-arc-why { padding: 36px 0; }
  .itl-arc-why__grid { grid-template-columns: 1fr; gap: 8px; }
  .itl-arc-why__item { padding: 14px 14px; gap: 10px; }
  .itl-arc-why__icon { font-size: 20px; }
  .itl-arc-why__text { font-size: 13px; }

  /* CTA section */
  .itl-arc-cta { padding: 40px 0; }
  .itl-arc-cta__title { font-size: clamp(20px, 6vw, 28px); }
  .itl-arc-cta__sub   { font-size: 14px; margin-bottom: 24px; }
  .itl-arc-cta__actions {
    flex-direction: column;
    align-items: stretch;
    gap: 8px;
  }
  .itl-arc-cta__btn {
    justify-content: center;
    min-height: 50px;
    padding: 14px 20px;
  }

  /* Section head */
  .itl-arc-section-head { padding: 20px 14px 0; }
  .itl-arc-section-head__title { font-size: 18px; }
}

/* ════════════════════ 480px — Small phone ══════════════════════════════ */
@media (max-width: 480px) {
  .itl-arc-body > main { padding: 16px 14px 28px; }
  .itl-arc-hero__stat-val { font-size: 20px; }
  .itl-arc-topbar { flex-direction: column; align-items: flex-start; gap: 4px; }
}


/* ── AJAX loading state ─────────────────────────────────────────────────── */
#itl-arc-results { transition: opacity .2s; }
#itl-arc-results.itl-arc-loading { opacity: .45; pointer-events: none; }

/* ── Formation archive ──────────────────────────────────────────────────────── */
.itl-arc-hero--formation {
  background: linear-gradient(135deg, #0b1630 0%, #065f46 100%);
}
.itl-arc-page--formation .itl-arc-sidebar__head {
  background: #065f46;
  color: rgba(255,255,255,.5);
}

/* Pagination links inside the results wrapper */
.itl-arc-pagination { margin-top: 28px; display: flex; flex-wrap: wrap; gap: 6px; justify-content: center; }
.itl-arc-pagination a,
.itl-arc-pagination span { display: inline-flex; align-items: center; justify-content: center; min-width: 36px; height: 36px; padding: 0 10px; border-radius: 6px; font-size: 13px; font-weight: 600; border: 1.5px solid #e2e5ef; color: #374163; text-decoration: none; transition: background .15s, border-color .15s, color .15s; }
.itl-arc-pagination a:hover { background: #f5f4f0; border-color: #0b1630; color: #0b1630; }
.itl-arc-pagination .current { background: #0b1630; border-color: #0b1630; color: #fff; }
