/* IM Markets — Frontend styles */
:root {
  --im-mkt-accent:   #1A1AFF;
  --im-mkt-up:       #16a34a;
  --im-mkt-down:     #dc2626;
  --im-mkt-flat:     #6b7280;
  --im-mkt-bg:       #000000;
  --im-mkt-border:   #e5e7eb;
  --im-mkt-text:     #111827;
  --im-mkt-muted:    #6b7280;
  --im-mkt-card-bg:  #f9fafb;
  --im-mkt-radius:   6px;
  --im-mkt-font:     -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}

.im-markets-root {
  font-family: var(--im-mkt-font);
  color: var(--im-mkt-text);
  background-color: var(--im-mkt-bg);
}

/* Full/Wide alignment */
.im-markets-root.alignfull  { width: 100vw; max-width: 100vw; margin-left: calc(50% - 50vw); margin-right: calc(50% - 50vw); }
.im-markets-root.alignwide  { width: 100%; max-width: var(--wp--style--global--wide-size, 1200px); margin-left: auto; margin-right: auto; }

/* ── Loading ── */
.im-markets-loading { display: flex; align-items: center; justify-content: center; padding: 2rem; }
.im-markets-spinner {
  width: 24px; height: 24px; border: 2px solid var(--im-mkt-border);
  border-top-color: var(--im-mkt-accent); border-radius: 50%;
  animation: im-mkt-spin .7s linear infinite;
}
@keyframes im-mkt-spin { to { transform: rotate(360deg); } }

/* ── Error ── */
.im-mkt-error { padding: 1rem; color: var(--im-mkt-muted); font-size: .875rem; text-align: center; }

/* ══════════════════════════════════════
   TICKER TAPE
══════════════════════════════════════ */
.im-mkt-ticker {
  overflow: hidden; white-space: nowrap;
  background: var(--im-mkt-bg, #0d0d0d); padding: .45rem 0;
  border-radius: var(--im-mkt-radius);
}
.im-mkt-ticker-track {
  display: inline-block;
  /* La durée est surchargée inline par JS via animation-duration */
  animation: im-mkt-scroll 60s linear infinite;
}
.im-mkt-ticker:hover .im-mkt-ticker-track { animation-play-state: paused; }
@keyframes im-mkt-scroll { from { transform: translateX(0); } to { transform: translateX(-50%); } }

.im-mkt-tick-item {
  display: inline-flex; align-items: center; gap: .4rem;
  padding: 0 1.2rem; font-size: .8rem; color: #e5e7eb;
  border-right: 1px solid rgba(255,255,255,.1);
}
.im-mkt-tick-label  { color: #9ca3af; font-size: .72rem; text-transform: uppercase; letter-spacing: .04em; }
.im-mkt-tick-price  { color: #f3f4f6; font-weight: 600; }
.im-mkt-tick-change { font-size: .72rem; }
.im-mkt-tick-item.im-mkt-up   .im-mkt-tick-change { color: var(--im-mkt-up,   #4ade80); }
.im-mkt-tick-item.im-mkt-down .im-mkt-tick-change { color: var(--im-mkt-down, #f87171); }
.im-mkt-tick-item.im-mkt-flat .im-mkt-tick-change { color: #9ca3af; }

/* ══════════════════════════════════════
   CARDS
══════════════════════════════════════ */
.im-mkt-cards-wrap { display: flex; flex-direction: column; gap: 1.5rem; padding: 1rem; }
.im-mkt-cat-title  { font-size: .7rem; text-transform: uppercase; letter-spacing: .08em; color: var(--im-mkt-muted); margin: 0 0 .6rem 0; }
.im-mkt-cards      { display: grid; grid-template-columns: repeat(auto-fill, minmax(140px, 1fr)); gap: .75rem; }

.im-mkt-card {
  background: var(--im-mkt-card-bg); border: 1px solid var(--im-mkt-border);
  border-radius: var(--im-mkt-radius); padding: .75rem 1rem;
  border-left: 3px solid var(--im-mkt-flat);
  transition: box-shadow .15s;
  color: var(--im-mkt-text);
}
.im-mkt-card:hover         { box-shadow: 0 2px 8px rgba(0,0,0,.15); }
.im-mkt-card-up            { border-left-color: var(--im-mkt-up); }
.im-mkt-card-down          { border-left-color: var(--im-mkt-down); }
.im-mkt-card-label         { font-size: .72rem; color: var(--im-mkt-muted); text-transform: uppercase; letter-spacing: .04em; margin-bottom: .3rem; }
.im-mkt-card-price         { font-size: 1.05rem; font-weight: 700; color: var(--im-mkt-text); }
.im-mkt-card-change        { font-size: .75rem; margin-top: .2rem; }
.im-mkt-card-up .im-mkt-card-change   { color: var(--im-mkt-up); }
.im-mkt-card-down .im-mkt-card-change { color: var(--im-mkt-down); }
.im-mkt-card-flat .im-mkt-card-change { color: var(--im-mkt-muted); }
.im-mkt-card-vol           { font-size: .68rem; color: var(--im-mkt-muted); margin-top: .25rem; }

/* ══════════════════════════════════════
   TABLE
══════════════════════════════════════ */
.im-mkt-table-wrap { overflow-x: auto; padding: .5rem; }
.im-mkt-table {
  width: 100%; border-collapse: collapse; font-size: .85rem;
  color: var(--im-mkt-text);
}
.im-mkt-table thead th {
  text-align: left; padding: .5rem .75rem;
  font-size: .68rem; text-transform: uppercase; letter-spacing: .06em;
  color: var(--im-mkt-muted); border-bottom: 2px solid var(--im-mkt-border);
}
.im-mkt-table tbody tr { border-bottom: 1px solid var(--im-mkt-border); }
.im-mkt-table tbody tr:hover { background: var(--im-mkt-card-bg); }
.im-mkt-table td { padding: .5rem .75rem; }

.im-mkt-td-label  { font-weight: 600; }
.im-mkt-td-ticker { color: var(--im-mkt-muted); font-size: .75rem; }
.im-mkt-td-price  { font-weight: 600; text-align: right; }
.im-mkt-td-change { text-align: right; }
.im-mkt-td-pct    { text-align: right; font-weight: 600; }
.im-mkt-td-vol    { text-align: right; color: var(--im-mkt-muted); font-size: .78rem; }

.im-mkt-row-up   .im-mkt-td-pct { color: var(--im-mkt-up); }
.im-mkt-row-down .im-mkt-td-pct { color: var(--im-mkt-down); }
.im-mkt-row-flat .im-mkt-td-pct { color: var(--im-mkt-muted); }
.im-mkt-row-up   .im-mkt-td-change { color: var(--im-mkt-up); }
.im-mkt-row-down .im-mkt-td-change { color: var(--im-mkt-down); }

.im-mkt-footer {
  text-align: right; font-size: .68rem; color: var(--im-mkt-muted);
  padding: .4rem .75rem; border-top: 1px solid var(--im-mkt-border);
}

/* ── Up/down direction classes ── */
.im-mkt-up   { color: var(--im-mkt-up); }
.im-mkt-down { color: var(--im-mkt-down); }
.im-mkt-flat { color: var(--im-mkt-muted); }

/* ── Responsive ── */
@media (max-width: 600px) {
  .im-mkt-cards { grid-template-columns: repeat(2, 1fr); }
  .im-mkt-td-ticker, .im-mkt-td-vol { display: none; }
}
