.otti-effects-search {
  width: 100%; padding: 8px 12px; margin-bottom: 12px;
  background: var(--otti-bg-card); border: 1px solid var(--otti-border);
  border-radius: var(--otti-radius-sm); color: var(--otti-text-primary);
}

.otti-favorites-row {
  display: flex; gap: 8px; overflow-x: auto; padding-bottom: 8px;
  margin-bottom: 12px;
}

.otti-effects-grid {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 8px;
}
@media (min-width: 1200px) {
  .otti-effects-grid { grid-template-columns: repeat(4, 1fr); }
}

.otti-effect-card {
  cursor: pointer; display: flex; flex-direction: column; align-items: center;
  padding: 8px 4px; border-radius: 10px; border: 2px solid transparent;
  transition: all 0.15s ease; background: var(--otti-bg-card);
}
.otti-effect-card.active {
  border-color: var(--otti-accent);
  box-shadow: 0 0 12px var(--otti-accent-light);
}
.otti-effect-card:hover { transform: scale(1.05); }

.otti-effect-emoji { font-size: 22px; margin-bottom: 4px; }
.otti-effect-name { font-size: 10px; text-align: center; }

.otti-effect-params {
  padding: 12px; border-top: 1px solid var(--otti-border); margin-top: 16px;
}
.otti-param-row {
  display: flex; align-items: center; gap: 8px; margin-bottom: 8px;
}
.otti-param-label { min-width: 80px; font-size: 12px; color: var(--otti-text-secondary); }
.otti-param-value { min-width: 36px; text-align: right; font-size: 12px; color: var(--otti-accent); }
