/* FIRMWAREFILE.UK — index.css */
.ff-index {
  --ix-bg: #eef2f6;
  --ix-surface: #ffffff;
  --ix-surface-2: #f6f8fb;
  --ix-border: rgba(15,23,42,.10);
  --ix-text: #101726;
  --ix-muted: #5f6977;
  --ix-faint: #8591a1;
  --ix-accent: #01696f;
  --ix-accent-hover: #0c4e54;
  --ix-shadow: 0 8px 30px rgba(15,23,42,.05);
  --ix-wrap: 1180px;
  background: var(--ix-bg);
  color: var(--ix-text);
  font-family: 'Inter', system-ui, sans-serif;
}
.ff-index-wrap { width: min(var(--ix-wrap), calc(100% - 32px)); margin-inline: auto; }
.ff-index-hero {
  padding: 32px 0 28px;
  background: linear-gradient(180deg, #07111f 0%, #0a1628 100%);
  color: #eaf0f6;
}
.ff-index-kicker {
  display: inline-block; margin-bottom: 14px; padding: 4px 10px; border-radius: 4px;
  background: rgba(78,201,208,.10); border: 1px solid rgba(78,201,208,.22);
  color: #8ee8ed; font-size: .73rem; font-weight: 800; text-transform: uppercase; letter-spacing: .08em;
}
.ff-index-title {
  margin: 0 0 12px; font-family: 'Outfit', system-ui, sans-serif;
  font-size: clamp(1.9rem,1.2rem + 2vw,3rem); line-height: 1.05; letter-spacing: -.03em; color: #eaf0f6;
}
.ff-index-sub { max-width: 68ch; margin: 0 0 18px; color: rgba(234,240,246,.72); line-height: 1.8; }
.ff-index-stats { display: grid; grid-template-columns: repeat(3, minmax(0, 160px)); gap: 12px; }
.ff-index-stats > div { padding: 12px 14px; border: 1px solid rgba(255,255,255,.10); background: rgba(255,255,255,.05); border-radius: 10px; }
.ff-index-stats strong { display: block; font-family: 'Outfit', system-ui, sans-serif; font-size: 1.35rem; color: #fff; }
.ff-index-stats span { font-size: .76rem; text-transform: uppercase; letter-spacing: .08em; color: rgba(234,240,246,.48); }
.ff-index-body { padding: 28px 0 64px; }
.ff-index-grid { display: grid; grid-template-columns: minmax(0,1fr) 280px; gap: 24px; align-items: start; }
.ff-index-list { display: flex; flex-direction: column; gap: 10px; }
.ff-index-item { padding: 16px 18px; background: var(--ix-surface); border: 1px solid var(--ix-border); border-radius: 10px; box-shadow: var(--ix-shadow); }
.ff-index-top { display: flex; gap: 10px; align-items: center; flex-wrap: wrap; margin-bottom: 6px; }
.ff-index-brand { display: inline-flex; align-items: center; padding: 4px 8px; border-radius: 4px; background: rgba(1,105,111,.08); border: 1px solid rgba(1,105,111,.15); color: var(--ix-accent); text-decoration: none; font-size: .76rem; font-weight: 700; letter-spacing: .05em; text-transform: uppercase; }
.ff-index-date { color: var(--ix-faint); font-size: .8rem; }
.ff-index-item-title { margin: 0 0 8px; font-family: 'Outfit', system-ui, sans-serif; font-size: 1.18rem; line-height: 1.15; }
.ff-index-item-title a { color: var(--ix-text); text-decoration: none; }
.ff-index-meta { display: flex; gap: 8px 16px; flex-wrap: wrap; margin-bottom: 8px; }
.ff-index-meta span { color: var(--ix-muted); font-size: .82rem; }
.ff-index-excerpt { margin: 0 0 12px; color: var(--ix-muted); line-height: 1.75; font-size: .94rem; max-width: 74ch; }
.ff-index-open { display: inline-flex; align-items: center; justify-content: center; min-height: 38px; padding: 0 14px; border-radius: 6px; background: #0f172a; color: #fff; text-decoration: none; font-size: .84rem; font-weight: 700; }
.ff-index-panel { padding: 16px; background: var(--ix-surface); border: 1px solid var(--ix-border); border-radius: 10px; box-shadow: var(--ix-shadow); }
.ff-index-panel + .ff-index-panel { margin-top: 14px; }
.ff-index-panel-title { margin: 0 0 12px; font-family: 'Outfit', system-ui, sans-serif; font-size: .84rem; font-weight: 800; text-transform: uppercase; letter-spacing: .08em; color: var(--ix-muted); }
.ff-index-panel p { margin: 0; color: var(--ix-muted); line-height: 1.75; font-size: .93rem; }
.ff-index-links { display: flex; flex-direction: column; gap: 8px; }
.ff-index-links a { color: var(--ix-text); text-decoration: none; font-weight: 600; }
.ff-index-pagination { margin-top: 20px; }
.ff-index-pagination .page-numbers { list-style: none; display: flex; flex-wrap: wrap; gap: 8px; padding: 0; margin: 0; }
.ff-index-pagination a, .ff-index-pagination span { display: inline-flex; align-items: center; justify-content: center; min-width: 40px; height: 40px; padding: 0 12px; background: var(--ix-surface); border: 1px solid var(--ix-border); border-radius: 6px; color: var(--ix-text); text-decoration: none; font-size: .88rem; font-weight: 600; }
.ff-index-pagination .current { background: var(--ix-accent); color: #fff; border-color: var(--ix-accent); }
.ff-index-empty { padding: 24px; background: var(--ix-surface); border: 1px solid var(--ix-border); border-radius: 10px; }
.ff-index-empty h2 { margin: 0 0 10px; font-family: 'Outfit', system-ui, sans-serif; }
.ff-index-empty p { margin: 0; color: var(--ix-muted); }
@media (max-width: 960px) { .ff-index-grid { grid-template-columns: 1fr; } }
@media (max-width: 680px) { .ff-index-stats { grid-template-columns: 1fr; } }
