/* OnlyFanOuts — Grid Systems, Spacing & Responsive Utilities */

/* Grid layouts */
.grid-2 { display: grid; grid-template-columns: repeat(2, 1fr); gap: 15px; }
.grid-3 { display: grid; grid-template-columns: repeat(3, 1fr); gap: 15px; }
.grid-4 { display: grid; grid-template-columns: repeat(4, 1fr); gap: 15px; }

@media (max-width: 768px) {
  .grid-2, .grid-3, .grid-4 { grid-template-columns: 1fr; }
}

/* KPI Grid */
.kpi-grid { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 12px; }
@media (max-width: 960px) { .kpi-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); } }
@media (max-width: 560px) { .kpi-grid { grid-template-columns: 1fr; } }

/* Stats row */
.stats-row { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 12px; margin-top: 12px; text-align: left; }
@media (max-width: 960px) { .stats-row { grid-template-columns: 1fr; } }

/* Date range */
.date-range { display: grid; grid-template-columns: 1fr 1fr; gap: 15px; }
@media (max-width: 560px) { .date-range { grid-template-columns: 1fr; } }

/* Config grid */
.config-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(250px, 1fr)); gap: 15px; }
.config-item { background: white; padding: 10px; border-radius: var(--radius-sm); }
.config-item strong { display: block; margin-bottom: 5px; color: #555; }

/* Weight section (visibility builder) */
.weight-section { display: grid; grid-template-columns: repeat(auto-fit, minmax(300px, 1fr)); gap: 15px; }
.weight-item { background: white; padding: 15px; border-radius: var(--radius-sm); }
.weight-item label { display: flex; justify-content: space-between; margin-bottom: 8px; }
.weight-value { color: var(--blue-700); font-weight: bold; }
input[type="range"] { width: 100%; }

/* Competitor rows */
.competitor-row {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr auto;
  gap: 10px;
  align-items: end;
  margin-bottom: 10px;
  padding: 10px;
  background: white;
  border-radius: var(--radius-sm);
}

/* Navigation row */
.nav { display: flex; justify-content: space-between; margin: 12px 0; }

/* Filter banner */
.filter-banner { margin: 12px 0; font-size: 15px; color: var(--gray-900); }

/* Row actions */
.row-actions { display: flex; align-items: center; gap: 8px; flex-wrap: nowrap; }
.row-actions a { margin-right: 8px; }

@media (max-width: 640px) {
  .row-actions { flex-direction: column; align-items: flex-start; gap: 8px; }
  .row-actions .btn { width: auto; }
}

/* Spacing utilities */
.text-center { text-align: center; }
.text-right { text-align: right; }
.mt-1 { margin-top: 8px; }
.mt-2 { margin-top: 16px; }
.mt-3 { margin-top: 24px; }
.mb-1 { margin-bottom: 8px; }
.mb-2 { margin-bottom: 16px; }
.mb-3 { margin-bottom: 24px; }
.hidden { display: none; }
